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PREFAŢĂ 


Mieroprocesorul, creație ce a răsărit în constelația siliciului începînd cu deceniul al 
8-lea al secolului XX, a cunoseut o evoluţie spectaculoasă, atingind în prezent cotele matu- 
rităţii, în ciuda tinereţii sale. Procesul evolutiv se datorește, în principal, rafinamentelor in- 
troduse în tehnologia prelucrării siliciului, nefiind — însă — de neglijat aportul noilor arhi- 
tecturi logice a prodsoarelor şi reacţia utilizatorilor acestora. 


În cursa microprocesoarelor s-au angajat mai mulți producători de componente electronice, 
avînd loc o emulaţie şi o selecţie a soluţiilor tehnice adoptate. Pentru clasa microproecesoarelor 
de 8 biți cursa a fost cîştigată de mieroprocesorul 280 lansat de firma ZILOG, denumit MMN 80 
CPU de către întreprinderea românească Mieroelectronica. Prezent în milioane și milioane de 
aplicații pe toate meridianele globului acest microprocesor dispune de o vastă acoperire cu 
programe de uz general sau de aplicaţie şi de o impresionantă bibliogratie. 

În țara noastră, graţie dezvoltării impetuoase a industriei electronice în ultimele două 
decenii, microprocesorul 280 este puternic implautat, constituind elementul esenţial al multor 
echipamente de tehnică de calcui şi automatizare cum ar fi calculatoarele personale PRAF, 
aMIC, HC-85, TIM-S, mieroealeulatoarele ECAROM, MADS, MIND, videoterminalele DAF 2020, 
VDT 52$, ete. Microprocesorul MMN 80 CPU şi circuitele MOS-LSI din familia sa MMN 80 
SIO, MMN 80 PIO, MMN 80 CTC şi MMN 80 DMA se află în producţie de serie la între- 
prinderea Miceroelectronica. Aceste realizări ale tinerei industrii electronice româneşti se găsese 
în exploatare în mai toate domeniile vieții economice şi sociale, formînd obiectul atenţiei 
zilnice a mii şi mii de specialişti. 

În acest context, prezenta lucrare constituie un prețios material de instruire și perfec- 
ţionare pus la dispoziția utilizatorilor și constructorilor echipamentelor ce utilizează micro- 
procesorul MMN 80 CPU. 

Nota de originalitate deosebită a cărții constă în prezentarea modului de funcționare 
a microprocesorului cu ajutorul unui program de simulare, care permite vizualizarea modiţi- 
cărilor stărilor interne pe măsura execuţiei eielurilor funcţionale. În acest scop, cartea este 
însoţită (o parte a tirajului) de un suport magnetie eonţinind programul de simulare, fiind 
astiel o apariţie inedită în peisajul editorial. 

Cele două volume conțin un bogat bagaj de cunoştinţe, plăcut și riguros prezentate, 
toate utile celor ce vor să se inițieze în tainele lui 2.00, precum şi celor deja inițiați în acest 
domeniu. 

Putem afirma că această carte conține totul (şi ehiar mai mult) despre Z80, avind 
în vedere, de exemplu, setul de instrucțiuni medeeclarate de firmă, dar descoperite în fară 
şi prezentate în capitolul G al părţii a II-a. 

Exersarea exemplului de proiectare hardware-software al unui echipament cu Z80, căruia 
îi este consacrat volumul 2, oferă cititorului un îndrumar practic bine conturat pentru abor- 
darea coerentă a unor proiecte bazate pe principiul logicii microprogramate. 

Rece: mandăm cu căldură această lucrare tuturor celor ce utilizează sau vor utiliza miero- 
procesorul Z80 sau alți confrați ai săi. Sintem convinși că, prin maniera tratării subiectului, 
cartea de .ață va contribui substanțial In răspindirea şi asimilarea rapidă a cunoştinţelor 
din acest domeniu de maxim interes pentru dezvoltarea economică şi soelală a patriei. 


Adresăm pe această cale felicitări redacţiei de informatică şi tehnică de calcul a Edi- 
turii Tehnice, pentru inițiativa de a publica cărți de profil însoţite de suport magnetic, 
cum şi autorului pentru irumoasa şi utila carte şi urăm elititorului o lectură plăcută şi 
instruetivă. i 


Bucureşti, 3 mai, 1989 


ing. GH. CONSTANTINESCU 


Directorul Intreprinderii 
Microelectronica 


CUVINT ÎNAINTE 


Ginduri la editarea de către Editura Tehnică a primei cărți româneşti 
însoţite de o casetă cu programe de calculator 


Cite cineva și-ar putea pune întrebarea dacă în anul 1989 se mai justifică edi- 
tared unei cărți dedicate unui microprocesor de 8 bit, microprocesorul Z80. 

Acest dubiu pare a fi susținut de numărul relativ mare de cărți care tratează 
această clasă de microprocesoare, apărute mai ales în străinătate, dar și în țară, 
cum și de faptul — că între timp — microprocesoarele de 16 și 32 bit cîștigă 
din „ce în ce mai mult teren. 

Microprocesorul Z80 nu este, însă, un oarecare. In afară de faptul că — pe 
plan mondial — a echipat numeroase calculatoare personale și o multitudine de 
echipamente, în țara noastră este creierul „electronic” al calculatoarelor personale 
românești PRAE, aMIC, HC—85, TIM—S ș.a., este fabricat pe scară largă de Uzina 
Microelectronica și constituie un component esențial al multor echipamente românești 
electronice și de automatizare. 

Elementul care ne-a dat o mai mare siguranță în abordarea acestei lucrări l-a 
reprezentat existența unor variante ale actualului program Visible— Z80, concepute 
de autor, în cadrul colectivului de la ITCI—Cluj-Napoca. 

Am considerat acest program — elaborat iterativ și finisat printr-o muncă de 
șapte ani — un mijloc care permite cunoașterea completă a funcţionării micropro- 
cesorului Z80. lar, de aici, înțelegerea altor microprocesoare va fi relativ simplă. 
Astfel, un alt microprocesor, mai simplu dar de mare răspîndire în lume și în Româ- 
nia, este 18080; cunoașterea „fratelui mai mare Z80'' constituie — implicit — o 
deplină stăpînire a lui 18080, cu care compatibilitatea unilaterală este rezolvată. 
Dar nu numai înţelegerea microprocesoarelor mai simple ci și a celor mai complicate, 
cu care se dotează (dar, mai ales, se prevede dotarea ) noile calculatoare personale 
românești, devine perfect posibilă. 

Visible—Z80. desenează pe ecranul televizorului sau monitorului unui calculator 
personal PRAE sau aMIC structura internă a microprocesorului Z80, ilustrînd prin 
grofică dinamică și semnale sonore toate activitățile desfășurate de acesta, atunci 
cînd el execută oricare din cele aproximativ 700 de" instrucţiuni pe care le recu- 
noaște. | 

Prin modul de abordare și prin facilităţile pe care le oferă, acest program 
poate fi considerat un unicat în materie, gîndit și realizat pentru o mai bună instruire 
(asistată de calculator ) la .nivel liceal și universitar, pentru oricine care utilizează 
sau — în mod necesar — va utiliza microprocesoarele. 

Iniţial, variante preliminare ale programului Visible—Z80 au fost implementate 
pe calculatorul personal PRAE—M, fiind preconizate a deveni „„port fanion''-ul software- 
ului utilizator al acestui calculator, realizat în c: drul aceluiași colectiv. Am testat 
utilitatea programului în procesul de instruire, pe grupe de elevi și studenţi, folosind 
primele versiuni operaţionale ale programului. Considerînd rezultatele obţinute drept 
bune, ne-am propus răspîndirea pe scară largă a programului, dorind să venim 
pe această cale în ajutorul tuturor celor care doresc .să înveţe utilizarea microproceso- 
rului Z80. In aceeași idee, am reconceput programul și pentru un alt calcu- 
lator personal din România, aMIC. Nu am reușit aceeași operație pe calculatoarele 
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compatibile cu. calculatorul Sinclair ZX Spectrum. (ex. HC—85, TIM—S), datorită 
imposibilității de a încadra imaginea generată de Visible—Z80Q în ecranul mai restrîns 
al acestor calculatoare (192x256 puncte, faţă de 256x256 la PRAE și aMIC). 


Pe acest drum ne-am. întîlnit cu ideile redacţiei de informatică și tehnică de 
de calcul a Editurii Tehnice, care urmărea de mai mult timp să editeze primele 
cărți din România însoţite de casete magnetice capabile să acționeze calculatoare 
personale. Redactorul. de specialitate a afirmat că, în 1980—81, cînd, aflat în 
Franţa, elabora pentru concernul de calculatoare IBM—France și pentru editorul 
internaţional Hachette o analiză de sistem în domeniul editării-fabricării-difuzării 
asistate a cărţii, a devenit preocupat și de frămîntările din „interiorul'' acestui uriaș 
editor (atunci, al 4-lea din lume) privind lansarea primelor cărți cu casete de cal- 
culator asociate ; deși o reclamă pentru *'... o ediție analizată pe calculator a lui 
Don Juan ..." trona de mult în vitrinele de pe Bd. Saint— Germain din Paris, 
vînzarea nu o lua din loc — spre bucuria concurenței americane, aflate: în avans, 
ca și a celei franceze — datorită unor probleme ca : preţul, protecția la copiere a 
casetei, drepturile de autor, de copyright, -de licenţe ș.a., fapt care trăda că „„dru- 
mul.nou și pentr-un uriaș e greu'.. 


Asemenea preocupări s-au putut concretiza la noi odată cu existenţa unor 
serii ale primelor calculatoare personale românești, PRAE și aMIC. 


In acest climat favorabil, după consultări prealabile, am depus editurii, în 
primăvara lui 1987, manuscrisul lucrării axat pe un volum, constind din două 
părți și ample anexe. 

Mai- apoi, “în toamna aceluiași an, după o conlucrare adincită cu redacţia, 
intra în tipografie manuscrisul unei cărți în două volume și trei părţi, din ciclul 
„Totul despre, . .", cu o structurare mai bună și mai „prietenoasă" față de un 
cerc larg de cititori, cu un ultim capitol complet nou și cu evidenţierea prin mul- 
tiple mijloace. (inclusiv culoarea) a unor accente semnificative ale unei ediţii unicat; 
între timp am colaborat cu Electrecord-ul pentru purierea la punct a eleitronicii 
înregistrărilor pe casete audio dedicate calculatoarelor. In primăvara lui 1988 edi- 
tura a obținut pentru carte și casete tiraje apreciabile, iar întreg textul cules a 
fost corectat; pregătirea pentru tiparul ofset în culori, găsirea unor materiale adec- 
vate, realizarea casetelor dar, mui ales, „„frămîntări economice editoriale” (ase- 
mănătoare, oare, celor de la kachette ?) ne-au adus în acest an. - 

Cînd ... revenim puţin la „disecarea'” complexei cărţi aflate acum în faţa 
cititorilor. 


* 


Iniţia. m-am gîndit la un manual de utilizare, bine exemplificat, al casetei 
VISIBLE—Z80. Am renunţat relativ repede la această idee, considerînd că numărul 
celor care doresc să-și aprofundeze cunoștințele despre microprocesorul Z80 este mult 
mai mare decit al celor care acced la calculatoarele personale PRAE și aMIC. Tre- 
buia, deci, scrisă o lucrare care să le permită și celor care nu acced la calculatoare 
personale condiţii bune de autoinstruire. Astfel am decis — așa cum a fost și opțiunea 
redacției — să introducem în text un număr mare de imagini, reprezentînd secvențe 
similare cu cele. generate de Visible—Z80 pe ecranul atașat unui calculator personal, 
astfel încît caseta să poată fi înțeleasă și în lipsa colculatorului (deci, numai din 
textul, figurile și programele imprimate ). 
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Am recurs la un stil, pe alocuri, eseist — mai rar întîlnit în literatura tehnică 
— dorind pe această cale să „colorez" uniformitatea aparentă a unui volum mare 
de imagini, în care doar cititorul atent putea sesiza diferențele. Am încercat să infil- 
trez picătură cu picătură, — fără a conturba continuitatea textului de bază — expe- 
riența acumulată în 10 ani de proiectare în domeniul microprocesoarelor. Am rezolvat 
acest lucru, de exemplu, înserînd informaţiile dorite sub forma unor remarci, pe care 
le veți regăsi numerotate de la 1 la 67. 

Din dorința de a veni în ajutorul cît mai multor cititori posibili (chiar. și profe- 
sioniști) am elaborat încă 'o parte — inclusă ca parte a doua în volumul | sub 
titlul Complemente —, din care aș dori să remarc studiul comparativ al seman- 
ticii limbajelor de asamblare) 18080 și Z80, menit să fundamenteze mai bine noțiunea 
de limbaj de asamblare, cum și listele instrucțiunilor microprocesorului Z80 (atît a 
celor declarate cît și a celor ascunse), grupate în ordine “alfabetică și în ordinea 
crescătoare a codurilor. Aceste din urmă liste au reprezentat un adevărat calvar. 
Ele au trecut prin 16 corecturi, la fiecare trecere găsindu-se încă erori. Nutrim spe- 
ranţa de a le fi eliminat pe toate, dar „,tăria'' afirmației o simţim puternic afectată, 
văzînd prin cîte am trecut ! 

Dar, rolul esenţial al complementelor pentru cititorii care au acces la un calcu- 


lator personal PRAE sau aMIC este manudlul de utilizare al casetei VISIBLE—Z80, 
care prezintă sistematic — pas cu pas — ce trebuie făcut pentru lucrul cu acest 
pachet de programe de simulare. 

Recitind materialul rezultat; mi-am spus : „„Toate bune'!. Cititorul poate afla 
totul despre modul în care microprocesorul Z80 execută instrucţiunile. Dar cum va 
şti el să-l utilizeze, să-l programeze ? Răspunsul la această întrebare s-a putut 
da doar elaborînd un al doilea volum. 


In ceea ce privește conținutul acestui volum, am hotărît să nu-l constitui dintr-un 
colaj de programe, adunate astfel încît să acopere cît mai bine setul de instrucţiuni 
al microprocesorului. Am analizat îndelung problema, știind că programele pe care 
le voi elabora vor trebui să se constituie într-un ansamblu unitar, care să aibă o 
finalitate. Iniţial m-am gîndit la elaborarea unui program monitor (se regăsește pe 
aproape toate microcalculatoarele ) — dar am renunţat la idee, datorită spectrului 
tematic relativ restrîns care putea fi acoperit (lipsa aproape totală a problemelor 
de interfaţă — hardware comandat prin program ), și datorită faptului că nu aș 
fi putut spune mai nimic nou. 

M-am jucat apoi cu ideea realizării software-ului pentru o imprimantă matricia- 
lă. Spectrul tematic al acesteia este mai bogat, dar nici aici nu apar calcule mate- 
matice. Ori, această clasă de probleme este una din cele care se pot rezolva destul 
de elegant cu microprocesoare, 

Continuîndu-mi căutările am ajuns la casa de marcat electronică. M-am bucurat 
mult văzînd că ea poate îngloba întregul “proiect de imprimantă, suplimentindu-l 
cu probleme de aritmetică și numeroase considerente de ergonomie. 

S-a născut astfel volumul al doilea, axat în special pe programarea microproceso- 
rului Z80 (software ), în care prezint toate etapele de proiectare a unei case elec- 
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tronice de marcat virtuale, începînd cu specificația ei tehnică și terminînd cu docu- 
mentația completă a programului. 


Am început volumul cu un capitol introductiv, prezentind noţiuni de progra- 
mare structurată și făcînd recomandări de ordin general (uneori chiar și detalii de 
tehnică ) privind modalităţile de realizare a unor programe cu „viaţă lungă". Pe 
parcursul elaborării proiectului am încercat să respect întocmai recomandările formulate 
în capitolul introductiv. Trebuie să recunosc că acest lucru nu a fost deloc ușor. 


Stilul folosit în acest volum este mai riguros, el solicitîndu-l probabil mai mult 
pe cititor. Am încercat să înlesnesc asimilarea informațiilor, redînd majoritatea progra- 
melor elaborate sub trei forme : organigramă, limbaj de nivel înalt (pseudo— Pascal ) 
și limbaj de asamblare. 

Predau cartea cititorilor, puţin emoţionat, adresînd-o atit celor începători cît 
și celor avansați ! j 


Mulţumiri 

Doresc să-mi exprim profunda gratitudine prietenilor mei; care m-au ajutat 
atît de mult în realizarea manuscrisului și produselor-program. 

Inainte de toate ţin să mulţumesc ing. Schneider Hans Rudolf, fără a cărui muncă 
plină de devotament programul Visible—Z80 n-ar fi fost ceea ce este. 


Aceleași sentimente. de recunoștință le port ing. Hidân Levente pentru ajutorul 
acordat la elaborarea studiului de caz din volumul 2. 


Șirul celor ce m-au ajutat — cu sugestii, sfaturi și participare, — la punerea 
la punct a programelor și a manuscrisului, a filelor și listelor de instrucţiuni, a figurilor 
și imaginilor, a:casetei este lung. Chiar și cu riscul de a omite pe unii, ţin să le mulțu- 
mesc nominal: ing. Dorin Barbul (CCMIM Baia Mare), mat. Kiss Alexandru, ing. 
Pop Baldi Nicolae, ing. Teodora Raţiu, ing. lImecs Mârton (Muzeul de istorie 
Cluj-Napoca), ing. Mirela Arion, ing. Radu Arsinte, fiz. Szâsz Detre, ing. Dinu 
Budura (Inst. Politehnic Timișoara), ing. Papp Hajnolka (IEIA Cluj-Napoca), ing. 
Ferencz Attila, ing. S6lyom Peter (intr. Republica Reghin), ing. Elena Rugină 
(Intr. Electrecord), cu o remurcă aparte privind adaptarea instalaţiei de înregis- 
trare pentru caseta de calculator. Cei mai mulţi, colegi la filiala ICSIT-TCI 

Îmi exprim aprecierea pentru spiritul creator, beri se fertilă instaurată de 


către conducerea Institutului de Cercetare Științifică și Inginerie Tehnologică pentru 
Tehnică de Calcul și Informatică (ICSIT—TCI) București, — ing. Victor Megheșan, 
dr. ing. Dan Roman, dr. Emil Munteanu (conducătorul filialei din Cluj-Napoca) — 
mediu de lucru care oferă spaţiu larg de desfășurare profesională tuturor tinerilor 
specialiști. i 
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iniţiativa de a lansa un asemenea gen de ediţie, în premieră românească. 
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Editura tehnică dorea de mult timp (chiar înaintea apariţiei primelor calculatoare 
personale româneşti, PRAE şi aMIC) să editeze, în redacţia de informatică și tehnică de 
calcul, primele cărți cu produse-program asociate, pe mediile magnetice disponibile (casete 
audio, dischete). 

Prima ofertă “acceptată a constituit chiar de la început o reală surpriză, calitatea 
produsului-program oferit — un. simulator audio-vizual complex al funcţionării micropro- 
cesorului Z80 și un proiect complet al unei case de marcat electronice — depășind cu mult 
așteptările de programe originale pentru calculatoare personale. 

Este adevărat că pachetul de programe — denumit VISIBLE-Z8O — a fost conceput 
chiar de către autorul calculatorului personal românesc PRAE, care l-a transpus ulterior și 
pe celălalt calculator personal românesc aMIC, primele produse de acest fel din ţară. 

Cartea care s-a dezvoltat în jurul acestui nucleu esenţial a fost concepută astfel încît 
funcționarea microprocesorului Z80 și proiectarea echipamentelor cu microprocesoare Z80 
să fie înţelese indiferent dacă cititcrii au sau nu acces la calculatoarele personale amintite. 

În esență, Visible-Z80 desenează pe ecranul unui televizor atașat la un calculator per- 
sonal structura internă a microprocesorului Z80 și simulează prin mişcare și sunet toate 
activitățile care au loc în interiorul microprocesorului, atunci cînd el execută oricare din cele 
696 de instrucţiuni publicate, pe care microprocesorul Z8O real le poate recunoaște și executa, 

În carte, setul de instrucțiuni și hardware-ul microprocesorului sînt prezentate cu 225 
secvenţe grafice indentice cu cele generate de simulatorul Z80, 

Activitățile majore din interiorul microprocesorului sînt subliniate prin efecte sonore 
specifice, permițînd utilizatorului identificarea lor simplă. Simularea grafică a tuturor instruc- 
țiunilor poate fi executată în 7 regimuri de simulare distincte, care permit adaptarea vi- 
tezei de simulare la cunoștințele fiecărui utilizator în parte, ea fiind foarte gustată de cei 
care doresc să se autoinstruiască. 

Existenţa regimului “de simulare Automat (simularea decurge automat cu o viteză 
programabilă) și a celui Manuai (simulatorul se oprește la sfirșitul, fiecărui ciclu, așteptînd 
apăsarea unei taste a calculatorului) facilitează utilizarea lui Visibla-Z80 de către profesori, 
ei putind da — în pauzele indefinit de lungi ale regimului manual — toate eventualele 
explicații necesare unei mai bune înţelegeri a fenomenelor demonstrate. 

Visibla-Z80 poate fi folosit ca" instrument de lucru şi de utilizatorii avansați, cone 
ținînd, pe lingă simulatorul grafic propriu-zis și supervizorul de simulare, încă trei com- 
ponente software majore : monitorul ,asamblorul și dezasamblorul. 

In prima parte a volumului 1 se prezintă exhaustiv structura și funcţionarea amănunţită 
a microprocesorului, iar în a doua parte, denumită ,Complemente .. ” sînt grupate ma- 
nualul de utilizare a casetei magnetice, comparaţia între limbajele de asamblare a două 
microprocesoare uzuale (Z30 şi 18080), fişele detaliate ale tuturor instrucţiunilor micro- 
procesorului Z80, pe clase și grupe, lista instrucţiunilor publicate de firmă si a celor desco- 
perite de utilizatori (inclusiv în colectivul ITCI Cluj-Nâpoca unde activează autorul). 

Volumul 2 este un studiu de caz foarte dezvoltat, da proiectare a unei case de mar- 
cat .electronice, cu microprocesor Z80, încheiat cu proiectul complet al casei de marcat 
scris în limbaj de asamblare, comentat, aproape excesiv, nu numai pe module ci chiar pe 
fiecare instrucţiune, Acest proiect este încărcat în cod binar și pe caseta magnetică. Se 
realizează astfei un excelent manual de instruire și de lucru pentru proiectanţii de aplicaţii, 
care sînt puși la încercare în ultimul capitol al cărții de o temă, la a cărei rezolvare, 
ecranul televizorului atașat calculatoarelor personale amintite devine „casa de marcat” 
proiectată. 


Ing. PATRUBÂNY MIKLOS, este cercetător știintific la Filiala din Cluj-Napoca a Institu- 
tului de Tehnică de Calcul şi Informatică (ICSIT— TC!) şi cadru didactic asociat la Institutul 
Politehnic din Cluj-Napoca. Este autorul unuia dintre primele două calculatoare personale 
tomânești, şi anume a calculatorului PRAE-M, pe care l-a prezentat specialiștilor la „Cercul 
utilizatorilur de Microcalculatoare şi Terminala Programabile”, în nciembrie 1982, la Buşteni. 
După ce a absolvit, Liceul Stephan Ludwig Roth (Mediaş, 1971), ciştigă prima ediţie a 
Olimpiadei profesionale studenţeşti. „Traian Lalescu” (Timişoara, 1973)”, ca student al 
Facuităţii de Electrotehnică din Cluj-Napoca. După un stagiu la secţia de circuite integrate 
a |Intreprinderii de Piese Radio şi Semiconductoare — Băneasa, îşi continuă activitatea pro- 
fesională la astualul loc de muncă, conducind elaborarea unei familii de calculatoare 
peisonale (Prae—M, Prae—Max,  Prae—Phoenix) şi produse software (MATH-I, 
MATH -—il), pvblicind totodată numeroase lucrări ştiinţifice în ţară și în străinătate. 
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M. PATRUBÂNY 


ALMOST EVERYTHING ABOUT ... THE Z80 MICROPROCESSOR 
TECHNICAL PUBLISHING HOUSE, BUKAREST, 1989 


The publication of this book dedicated to the detailed presentation of a well proved 
microprocessor — Z80 — represents an editorial novelty in Romania. It is the first book 
published together with a program cassette. 

The magnetic cassette contains two versions of Visible—Z80. This program, elaborated 
by a team led by the author, was implemented on two Romanian personal computers : Prae: 
and aMIC. It is the result of about 10 man. years work. Visible—Z80 is a complex audio- 
visual simulator, whose succesive versions have been submitted to exhaustive tests. Now 
it represents an excellent means of computer aided instruction for all those who want to 
initiate themselves in the world of microprocessors. 

Essentially Visible—Z80 draws on the screen of a TV-set connected to a personal 
computer, the internal structure of the Z8O microprocessor and it simulates through move- 
ment and sound all the activities that take place inside the microprocessor, when it executes 
any of the 696 published instructions which the Z80 microprocessor can really recognize: 
and execute, 

Main activities inside the microprocessor are underlined by specific sound effects which 
permit the user their simple identification. The graphic simulation of each instruction can be: 
carried out in 7 distinct simulation modes. First of all there is the basic mode which is more: 
detailed then the microprocessor's clock by clock cycle mode. There follow simulation modes 
going through the machine cycle mode and reaching two fast modes: the trace mode and 
the invisible mode. In each mentioned mode the simulation speed can be varied between 
high limits : 3 screen activities/s—0.3 screen activities/s. This facility permits the adaptation: 
of the simulation speed to each user's knowledge level. This feature is adored especially: 
by those who want to learn by themselves. 

The existence of the automatic simulation mode and of the manual one enhances the: 
use of Visible—Z80 by teachers. In the automatic mode simulation proceeds automatically 
with a programable speed, while in the manual one the simulator stops at the end of each 
cycle waiting until a key is pressed. In this latter mode — during.the indefinitly long brakes —, 
teacher may give all the eventual explanations necessary for the better understanding of the 
demonstated phenomena. 

Experimentation of Visible—Z80 with groups of pupils and students demonstrates a 
sensible diminution of the time necessary for study. In atout two or three weeks of daily 
study Visible—Z80 users learn in detail the instruction set. This is an important step for 
all those who are going to write programs in assembly language. They can also accomodate 
with many of the Z8O's hardware secrets, because Visible—Z80 is able to simulate the 
microprocessor's behaviour even in some specific hardware activities: RESET, BUSRO, NMI, 
INT. The user can simulate the activation of any of these signals pressing a key (R,B,N 
or |), on the computer's keyboard, while Visible—Z80 executes the simulation of any ins- 
truction. 

But Visible—Z80 isn't only an instrument for study. Beside the instruction simulator 
and the simulation supervisor, Visible—Z80 contains other three major software components : 

— the enclosed monitor : is a useful program, that permits the direct acces to memory 

and to the microprocessor's internal registers. It is intended to aid debugging of 
programs written in assembly language ; 

— the enclosed assembler: translates a program written in Z80 assembly language 

into machine code; 

— the enclosed disassembler : executes the inverse operation to the assembler. 

This is why Visible—Z80 can be considered a working tool even by more advanced users. 

The present book has been conceived in a way that it may allow to exploit the 
facilities offered by Visible—Z80 in the highest degree. Therefore, the reader may use a 
computer or not. It's so because the presentation of the instruction set and that of the 
microprocessor's hardware (volume 1) has been done with the heip of 225 graphic sequen- 
ces identical with those generated by Visible—Z80. 

But knowledge of a processor's hardware and its instruction set isn't enough to bea 
good user of it. It is obviously necessary to learn programming in assembly language. This 
is why we have elaborated volume 2, which presents the whole elaboration process of an 
equipment controlled by a microprocessor : an electronic cash register. 
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Below we present briefly the contens of each chapter. 

The prelude consists of three distinct paragraphs. The first one gives a short history 
of the events which contributed to the appearance of the computer called „„von Neumann 
machine” and it emphasises the indirect contribution of men like John Atanasoff, Alan Turing, 
Konrad Zuse. In the second paragraph it is constituted the functional structure of a central 
processing unit, in other words the one of a microprocessor. The last paragraph has the 
role of introducing the reader in the world of binary numbers — used in all the digital 
computers. 


In chapter 1 and 2 the hardware structure of the Z8O microprocessor is reveiled. The 
presentation of the internal structure is done using the funtional blocks defined in Praelu- 
dium and shown in images generated by Visible—Z80, We point out that in the block 
scheme defined by us there appear a few new elements — unpublished up to this time, 
Their taking into consideration proved to be necessary in order to simulate more faithfully 
the internal activities of the microprocessor. 


Chapter 3 is intended to introduce the term of instruction set. For a better undero 
standing presentation is done comparatively for two microprocessors. |n the same time this 
chapter tries a rigurous classification of the addressing techniques. It also tries to eliminate 
some incoherent ambiguities that still exist in different bibliographical sources. At the end 
of the chapter there is published a possible classification of the Z80 microprocessor's in- 
structions. They are grouped into 12. classes constituted of 98 instruction groups. 


Chapter 4 presents the basic working cycles of the processor in case. The reader is 
guided by means of a double visualization ;time diagrams and graphic sequences generated 
by Visible—Z80. In this way things may be understood even by readers who didn't got 
familiarized with time diagrams yet. 

There is also presented a machine cycle undetailed in the existing literature : the inter- 
nal machine cycle. 

Starting with chapter 5 the book presents the whole instruction set using intensiveiy 
the above mentioned audiovisual simulator. The text's style is essayistic, also easy to follow 
by the beginner. 

The elements, which couldn't be touched in the graphic sequences or those which 
“result from the author's experience of 10 years' work in this field, are concentrated in 
remarks numbered from 1 to 67. 


Chapter 5 is dedicated to transfer instructions of 8 and 16 bit data. It also presents the 
data block transfer instructions as: LDIR, LDDR, LDI, LDD. 

In chapter 6 the arithmetic/logic instructions follow, starting with the simple inter- 
register ones up to those applied to data blocks of variable lenght. 

The next chapter joins into a single adventure — not in the last instance to break 
the monotony of some sequences containing instructions of the same type —, instructions 
belonging to more classes. There are presented the jump instructions, those which call 
and return from subroutines, as well as those for bit manipulation (BIT, SET, RES), res- 
pectively rotate and shift instructions. 


„__ The author insists upon the details trying to clear up more and more secrets of Z80's 
"life". (Have you ever asked yourself: why does the number of clock cycles of an ordinary 
return instruction differ from those of a conditioned one (i.e. RET NZ and RET)? If you 
haven't, you can find the answer in chapter 7. 

Chapter 8 is dedicated to the input/outout instructions. 


Chapter 9 introduces — using again a dual presetation mode (time diagrams and-imaă- 
ges generated by Visible—Z80) — the special machine cycles. In the same time it introduces 
some system control instructions. The readers can get aquainted with interupts, with acces 
to the system buses, with wait states and halt cycles. 


The second part of volume 1. presents complementary informations to those described 
în the first part of the same volume. Therefore the chapters of this part have been noted 
with letters (A—G)' 

A Chapter A is the user manual of the Visible—Z80 cassette. There are presented both 
implementations : the one runnig on Prae and the other one working on aMIC. 

The manual describes the 5 major parts of which Visible—Z380 is constituted : monitor, 
assembler, disassembler, instruction simulator and simulation supervisor. 


The reader's initiation into the use of Visible—Z80 is done with the help of images 
generated by Visible—Z80 itself, 
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Chapter B is a test report wich describes the activities carried out during the about 
1,500 testing hours to which the simulator was submitted before this publication. The 
chapter ends with a facsimile page containing the image of one of the more than 700 test 
cards which resulted from testing. The author invites all readers and users to communicate 
any error that would appear during the use of Visible—Z80. 


Chapter C compares the assembly languages of two microprocessors (18080 and Z80), 
insisting upon their semantic differences. The chapter's conclusion is that Intel mnemonics 
are tightly related to the physical reality of the processor, while the Zilog ones, keeping 
apart from it, offer a greater liberty to the programmer. 


Chapter D is exclusively dedicated to those who want to build systems with the 
help of Z80 microprocessor. There are repeated the detailed time diagrams of basic pro- 
cessor cycles. In order to help the users, the author specifies those 17 timings (from the 53 
presented altogether) which must be assured by the hardware designer. 


Chapter E contains a card for each of the 98 instructrution groups defined by the 
author. The informations included in the instruction cards are: generic mnemonic, number 
of instructions of the considered group, instruction !enght (bytes), instruction duration (clock 
cycles), the instruction's structure, the addressing modes used, a code memento- with the 
intention to facilitate the discovery of some code-building rules-, affected flags, as well as 
references to the pages of.volume 2, where these instructions can be seen “in vivo” (în 
real programs). 


From those announced above, results thata proffesionist programmer can find-—in this 
chapter — all the information that will be necessary in his work. 


Chapter F contains a list of all the published instructions (696) of the Z80 micro- 
processor, ordered alphabetically and in increasing order of the codes. 


Chapter G insists upon the 458 “hidden instructions” discovered by users, but unpub- 
lished by manufacturers. 


Volume 2 intends to be a very detailed case-study presenting the complete project 
on an electronic cash register. So it constitutes to an example of structured programming, 
in assembly language. 


Chapter 10 presents the main elements and methods recommandable to those who 
want to write quality software. 


Chapter 11 contains the technica! specification of the product which will be elabo- 
rated on the next pages. It specifies, in the same time, the constructive and structural 
elements and the functional and ergonomic ones of the considered cash register. 


The cash register will be provided with 7 special functions, ranging from work session . 
programming to the sale's sythesis of a day, sales sorted, on product items. 


The project's result will have to satisfy entirely all requirements formulated in this 
chapter. 


In chapter 12, dedicated to the hardware elements the project of man-machine inter- 
faces is elaborated. These interfaces are intended to be poor as hardware. So the possibility 
appears to elaborate some first software modules. . 


We mention that in the sound generator's project the implementation's performance 
is checked. For this purpose it is published a Basic program, too. 


The design of hardware structure ends in diagram of the cash register's architecture- 


input/output elements are especially pointed out because their knowledge is necessary to 
launch the main software project. 


Before starting the elaboratior, of pure-software (non hardware related) modules, în 
chapter 13 there. are defined the main data structures as they derive from the technical 
specification (chapter 11). Inernal codes, character generators, input/output buffers, BCD 
registers, parameters and variabies appear. 


The chapter ends with the draft of the expected data flow in the cash register. 

In chapters 14—16 all the software modules are written which are going to make 
up the cash register as it was defined in chapter 11. 

The foilowed procedure is the top-down one, starting from the main program and 
finishing with the last element of detail. The general method used is the following : first 


of al! imposed functions and features are ennumerated followed by the according flowchart 
The flowchart is afterwards described in a high level language (“pseudo” Pascal). The consi- 
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dered module's description is finalized by elaborating the equivalent program in assembly 
language. The program lines are numbered because in the notes that follow, the used tech- 
niques will be explained by making references to these line numbers. The notes which follow 
each written module, ofteniy contain suggestions for other possible solutions. 

The problems treated in these four chapters cover a large area: BCD arithmetic, syn- 
tactic analysis, code conversion, test and service routines, system initialization and super- 
vizing modules. 

Chapter 17 contains the whole listing of the created software. 

Chapter 18 insits upon elements little tasted by programmers : the elaboration of docu- 
mentation wich will be able to ensure the software's serviceability even after years. 

In chapter 19 instead of problems and exercises, a work theme is announced, Those 
who will succed in writing the software modules necessary to implement the given theme, 
will see the cash register coming to life on the computer's screen and in the same time 
they can consider themselves fermed programmers. 
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„„Muncește cu sîrg şi cu har 
Cum astrul se mișcă pe cer 
solitar**e 


JOzsef Attila 


Am trăit o reală surpriză, cînd la Conferința “Children in an Information Age” 
desfășurată sub egida UNESCO în 1985 la Varna, un domn bătrîn,.pe nume 
John Atanasoffa fost prezentat drept autorul primului calculator electronic modern.. 
Pînă în acel moment „,paternitatea"” atribuită lui John von Neumann părea de 
necontestat, ca și informaţia conform căreia primul calculator electronic din lume 
a fost ENIAC, iar numele domnului John Atanasoff nu fusese amintit în legă- 
tură cu acest proiect. Întrucît afirmația fusese făcută în plen, în fața a sute de 
specialişti întruniți din toate colțurile lumii, ea nu putea fi lipsită de adevăr. lată 
de ce am simţit nevoia de a întreprinde cîteva cercetări bibliografice pentru eluci- 
darea acestei întrebări cheie. 

S-a demonstrat că John von Neumann nici nu știuse de proiectul ENIAC pînă 
la demararea lucrărilor de realizare fizică a proiectului deja elaborat. Apoi am 
aflat că mai sînt cel puţin o duzină de revendicări formulate din diverse părți 
ale globului, legate de numele unor specialiști remarcabili, din rîndul cărora ît 
amintim pe Konrad Zuse, Alan Turing, John W, Mauchly, J. Presper Eckert jr. 

Concluziile la care am ajuns fiind interesante, am decis includerea sintezei 
lor în prezenta carte, dedicată aproape exclusiv unității centrale .a calculatoru- 
lui actual — microprocesorul — 

La mijlocul anilor '30 tehnica electronică (bazată pe tuburi) a ajuns la un 
nivel de dezvoltare care i-a permis aplicarea în domenii din ce în ce mai diverse, 
Le ii limitele radiofoniei. 

n mai multe centre universitare din Europa și America s-au demarat cer- 
cetări pentru îmbunătățirea pe cale electronică a performanțelor calculatoarelor 
electromecanice deja existente. 

În primăvara anului 1943 la Institutul Moore al Universității Pennsylvania, 
john W. Mauchly propunea realizarea unui calculator digital complet electronic. 


* În românește de Mihai Beniuc: 


4 — Totul despre microprocesorul Z 80 vol. 1 şi 2 


lată cum prezenta împreună cu J]. G. Brainerd și |. P. Eckert modelul cal- 
<ulatorului propus : 

„După cum aminteam, pentru obţinerea rezultatelor dorite calculatorul electronic 
+a folosi principiul contorizării. De aceea el nu este altceva decît analogul electronic 
al mașinilor mecanice de adunare, înmulţire și împărţire care se fabrică în zilele 
noastre în scopul efectuării unor operații aritmetice. Structura constructivă a calcula- 
torului electronic permite însă realizarea unor comunicaţii între diversele sale părţi 
componente, putîndu-se realiza ostfel cicluri de funcţionare, care vor permite, în 
limita posibilităţilor, calcularea oricăror ecuaţii diferenţiale, prin iterații succesive. 

Rezultatul unei operaţii, de exemplu cel al unei înmulţiri, poate fi folosit ne- 
mijlocit în cadrul altor calcule succesive, conform modulului impus de ecuaţiile ce 
„„guvernează”' problema de rezolvat. Aceste numere vor putea fi transferate în caz 
de nevoie dintr-o componentă a sistemului în alta, fără ca în prealabil să fim nevoiţi 
a le copia manual pe hirtie, sau în componenta destinaţie, așa cum ar fi necesar 
dacă rezolvarea iterativă s-ar face cu calculatoare ordinare". 

Trebuie să amintim faptul că ]. W. Mauchly a avut consfătuiri cu John Atana- 
soff de la Institutul Superior de Stat din lowa, care experimentase deja unele 
modalități de rapidizare pe cale electronică a mașinilor de calcul obișnuite. 

Astfel, cînd la data de 1 iulie 1943 se lansa proiectul ENIAC (Electronic 
Numeric Integrator and Calculator) existau de acum cîteva calculatoare dotate cu 
facilități electronice. 


Proiectul electronic al calculatorului ENIAC s-a terminat în aproximativ 
1 an. La realizarea lui a participat un grup de ingineri deosebit de dotați, conduşi 
de |. Presper Eckert jr. lată numele cîtorva care au jucat un tol important în 
derularea acestei munci creatoare desfășurate zi și noapte de-a lungul celor aproa- 
pe 3 ani (ultimii doi dedicăţi realizării fizice) : John W. Mauchly, Arthur W. Burks, 
Joseph Chedaker, Chuan Chu, John H. Davis, Adele K. Golstine, Harry Huskey, 
T, Kite Sharpless și Robert Show. 

La data de 15.02.1946 ENIAC — deci primul calculator complet electronic, 
se predă beneficiarului. ENIAC — o construcție gigant (conținea aproximativ 
20.CCO tuburi electrenice) vehicula numere zecimale. În memoria sa nu se puteau 
înmagazina decît -20 de numere cu 10 cifre semnificative. ENIAC nu a fost un 
calculater programabil în accepțiunea de astăzi a cuvîntului, ci a permis doar 
realizarea unor bucle iterative pentru înlănțuirea operaţiilcr aritmetice de bază. 

Cu toată lipsa sa de fiabilitate — datorită duratei de viaţă limitate a tuburilor 
electronice folosite — și a memoriei sale limitate, ENIAC a reușit să învingă 
toate reținerile formulate la adresa calculatorului electronic, prin viteza de cal- 
cul ridicată, 

Comparînd performanţele lui cu calculatorul electremecanic Mark | se cons- 
tată că acesta din urmă rezolva ecuația diferenţială parțială formulată de Neu- 
mann, în €0 ore, pe cînd folcsind ENIAC prcblema se rezolva în aproximativ 
30 minute din care 28 minute se consumau pentru perfcrerea cartelelcr necesare 
memarării temporare a valoriler intermediare de calcul. (Calculatorul Mark î 
realizat sub conducerea profesorului Hcward Aiken la Universitatea Harvard 
a fost un calculator electromecanic ce cenținea aproximativ 7€O.CCO piese. Acesta 
a fost calculatorul care funcţionînd ani în șir fără ercare, a întemeiat supremația 
mondială a firmei EM, înființată încă din 1911 sub numele de Cc mputing Tabula- 
tion Ccmpany. Printre membrii fendatcri îl găsim și pe Hermann Hcllerith, 
cel care a elatcrat cartelele perfcrate care se. folosesc pînă în ziua de astăzi). 


2 PRAELUDIL 


John von Neumann, care trăia în orașul în care se elabora proiectul ENIAC, 
n-a fost cooptat decît în momentul în care lucrările au ajuns în faza execuţiei 
fizice a calculatorului. 


lată deci, deși n-a participat la elaborarea primului calculator complet elec- 
tronic, Neumann urma să devină prin contribuţia sa teoretică esențială în fundamen- 
torea următoarelor proiecte, cel care avea să fie privit drept fondatorul calcula- 
toarelor moderne. 


Cooptarea lui Neumann s-a făcut în vara anului 1944. Fiind deosebit de 
interesat în utilizarea unui calculator rapid pentru rezolvarea unor ecuaţii de 
tipul celei amintite, el s-a implicat profund în proiectul ce se derula, remarcînd 
cîteva insuficiențe ale acestuia. Ideea fundamentală care s-a cristalizat în perioada 
21 aug. — 2 septembrie 1944, în cadrul discuţiilor cu autorii proiectului ENIAC 
a fost aceea de a înmagazina în memoria calculatorului pe lîngă datele calculate, 
însuşi programul, automatizîndu-se astfel întreaga activitate a calculatorului. 


Nu se poate ști exact cine din cei participanţi la discuţii a formulat această 
idee. Neumann a scris-o pe hirtie, dezvoltînd-o și detailînd-o la nivelul unui proiect 
logic care avea să fundamenteze structura constructivă și funcțională a calcu- 
latorului electronic. Cert este că Neumann a fost catalizatorul discuţiilor, și faptul 
că el cunoscuse lucrările lui Alan Turing. 


Alan Turing un tînăr matematician englez care și-a realizat lucrarea de doc- 
torat la Universitatea din Princeton, a elaborat o lucrare care poate fi considerată 
esențială în fundamentarea matematică a științei calculatoarelor. Numele lui se 
vehiculează mai rar în analele istoriei calculatoarelor electronice, deoarece el nu 
a acceptat postul de asistent al lui John von Neumann, ofertă care probabil i-ar 
fi deschis calea către o strălucită afirmare profesională, ci a preferat să se întoar- 
că în ţara sa natală pentru a se angaja la Ministerul Afacerilor Externe, aducîndu-şi 
pe această cale aportul la lupta împotriva pericolului fascist iminent. 


Alan Turing a elaborat conceptul numerelor „,calculabile””, termen care-i 
aparține. Numerele calculabile sînt acele numere reale a căror parte zecimală 
se poate determina printr-un număr finit de iterații. Marele lui merit constă în 
aceea, că a demonstrat faptul că există un automat universal care poate deter- 
mina numerele calculabile și a elaborat modelul unui asemenea automat. 

Automatul lui Turing este desigur unul matematic, abstract. lată esența 
lui : 

a) automatul are un număr de n stări finite; 

b) automatul se află în orice moment într-o stare i, unde 1si sn urmînd 
ca în momentul următor să treacă într-o altă stare j (1 <j <n). 

c) fiecare stare este caracterizată prin următoarele informații : 

1. Valoarea caracteristică e; (o valoare „,curentă”' a numărului de cal- 
culat) 

2. Funcţia f; care se va aplica valorii caracteristice e, pentru a obține 
următoarea valoare caracteristică e; 

3. Deplasamentul d; care va trebui aplicat numărului i pentru a se deter- 
mina starea j: j =i + dj 

Prin aceste elemente automatul universal este complet definit. Încercînd să 
concretizăm modelul de mai sus, ne vom închipui o bandă de hirtie pe care 
sînt marcate, de exemplu prin găuri, n cîmpuri de date aferente celor n stări 


distincte ale automatului. (A nu se confunda cu banda de hîrtie perforată folo- 
sită curent în tehnica de calcul a anilor '70). 


Fiecare cîmp de date conţine cele 3 mărimi din informaţia de stare, enume- 
rate la pct. c) și o zonă de manevră pe care se poate șterge și înregistra o nouă 
valoare numerică. Automatul fizic va fi apt să deplaseze banda înainte și înapoi 
cu un număr de poziții dy. El își va desfășura activitatea permanent pe baza 
informațiilor citite de pe bandă. 

Să presupunem că automatul se află în starea i (în dreptul cîmpului de date 
i). Va citi valoarea caracteristică e;, îi aplică funcţia f;, citită din același cîmp 
de date, urmînd ca apoi să citească deplasamentul dy, cu care va trebui să miște 
banda înainte sau înapoi pentru a ajunge în starea următoare j. 

Acesta este modelul automatului universal. Dacă specificăm mărimile e,, : 
fi, d unde i, je [1, n] atunci s-a definit un automat dedicat, care va rezolva: 
problema impusă. Ce altceva este automatul universal al lui Turing, decît mode- 
lul matematic al unui calculator cu program memorat ? 

Pentru a se elimina deficiențele constatate ale calculatorului ENIAC, cu apro- 
ximativ 17 luni înainte de realizarea lui fizică s-a demarat proiectul unui nou cal- 
culator, EDVAC (13 septembrie 1944). 


În cadrul acestui proiect, Neumann a elaborat o lucrare intitulată „First 
draft of a report on the EDVAC”', (30 iulie 1945), o lucrare de bază în care pro- 
pune structura funcțională a calculatorului, circuitele sale logice, cum şi setul de 
instrucțiuni. 

Jlustrînd modul de utilizare (programare) a acestui set de instrucțiuni, lucrarea 
conține și implementarea unui algoritm de clasificare — sortare. 


O dată cu terminarea războiului, grupul EDVAC s-a destrămat. Cei care 
au rămas la Princeton au abordat la Institute for Advanced Study (IAS) proiectul 
unui nou calculator ce urma să fie un calculator binar, inspirîndu-se în realizarea 
ee i din tehnica tuburilor cinescop, și avînd o unitate de prelucrare para- 
elă. 

Pentru prima dată s-au separat colective de lucru pentru proiectarea logică 
și pentru cea hardware. Alături de Neumann, care a condus proiectul logic va 
trebui să-i amintim și pe Herman H. Goldstine, Julian Bigelow și James Pomerene. 

Proiectul s-a finalizat, rezultatul fiind calculatorul care poartă diverse nume : 
IAS, Princeton, mașina Neumann, MANIAC, sau Johnniac. 

Pe lîngă impunerea sistemului de numerație binar, și pe lîngă memorarea 
programului s-a constituit și structura logică a calculatorului electronic digital. 

Se disting de acum părțile funcționale majore : 

— unitate centrală 

— memorie 

— dispozitive de intrare/ieșire 

Unitatea centrală va cunoaște un set de instrucțiuni, codificate binar, care 
vor fi citite rînd pe rînd din memoria de lucru. Unitatea centrală va decodifica 
şi executa instrucțiunea curentă, urmînd să treacă controlul la instrucțiunea urmă- 
toare. 

Aceasta este mașina de referință pentru următoarele 4 decenii ale tehnicii 
de calcul. 

Amintind că prima demonstrație de teleprelucrare de date s-a făcut în 1940 
(Bell Telephone Laboratories — Stibitz și Andrew) între Dartmouth și New York 
folosind o mașină de telex și un calculator electromecanic, încheiem prezentarea 
istoriei apariției calculatoarelor electronice cu program memorat. Va trebui să 
constatăm, că aidoma multor altor descoperiri tehnice și științifice, şi apariţia 
acestor calculatoare este rodul unui larg și îndelungat proces de creație umană.. 


A 


Nu putem trece cu vederea contribuţiile anterioare : Descartes (1647), Pascal 
(1650), Leibnitz (1673) și Babbage (1822, 1833) ș.a. 

n anii 1940 crearea calculatorului electronic modern „plutea în aer”', ea 
fiind iminentă. John von Neumann a fost cel care. prin asimilarea rezultatelor 
parțiale, mai de mult sau mai de curînd create, a reușit să elaboreze o sinteză cali- 
tativ nouă. 


În anul 1964, Gordon E. Moore — director, la vremea respectivă, la Centrul 
de cercetări al firmei Fairchild — a remarcat faptul că de la apariția primului 
tranzistor planar (1958 — Jean Hoerni, la  Fairchild) numărul tranzistoarelor 
planare create pe aceeași structură de siliciu s-a dublat anual. În acest moment 
el a lansat ideea, care de atunci îi poartă numele, afirmînd că acest ritm de dez- 
voltare se poate menține de-a lungul a cîtorva decenii. Conform „Legii” lui 
Moore, după 22 de ani o structură de circuit integrat va fi putut conține 22, 
adică mai mult de 4 milioane de elemente de circuit electronice. Previziunea s-a 
adeverit. În anul 1986 s-au realizat primele circuite integrate de memorie, avînd 
capacitatea de 4 Mbit (4 milioane bit). 


Dacă o suprafață de aproximativ 2 cm? trebuie să conţină 4 milioane de 
elemente distincte, atunci dimensiunea medie a unui element va fi de 50 um?. 
Grosimea traseelor de legătură între elemente este mai mică de 1 um. 


Ţinînd cont de aceste exigențe, cerințele tehnologice impun anumite „reguli 
de joc'' extrem de severe. Să amintim doar două din ele. Puritatea materialelor 
chimice care se folosesc în procesul de elaborare a structurii de circuit integrat 
trebuie să depășească 99,9999999%. In încăperile de lucru, numărul particulelor 
de praf a căror diametru este mai mare decît 1 um nu are voie să depășească 
limita de 2700 particule/m? de aer, 


Pentru a oferi un termen de comparație, amintim faptul că cerințele impuse 
celor mai sterile săli de operaţie din clinici se limitează la nivelul de 270.000 par- 
ticule/m?. 

Rigoarea unor asemenea cerințe tehnologice este răsplătită prin dezvoltarea 
exponențială a acestei ramuri industriale, în care ponderea inteligenței încorporate 
în produse depășește cu multe ordine de mărime pe cea a materiilor prime și a 
energiei consumate în procesul de fabricație. Astfel s-a ajuns ca după 40 de ani de 
existență a industriei de calculatoare electronice, cel mai simplu calculator perso- 
nal, (care încorporează un microprocesor cu valoare aproximativ 6 $ și al cărui 
preț total nu depășește valoarea de 150$) să depășească net, la toate capitolele 
de performanţă, calculatoarele electronice din prima generație. Dacă ar fi să 
comparăm un calculator personal, bun de larg consum, cu primul calculator 
electronic, ENIAC, constatăm că obiectul nostru este de 40 de ori mai rapid, 
capacitatea sa de memorie este de 300 de ori mai mare, fiabilitatea sa este mai 
mare de mii de ori. Prețul scade de 20.000 ori, iar gabaritul cu un factor de 
30.000. Pe cînd ENIAC consuma o putere echivalentă cu cea a unei locomotive, 
întregul sistem microcalculator (calculator, televizor, casetofon) nu necesită mai 
multă energie electrică decît un bec de 100 W. 


Lumea microelectronicii este o lume fabuloasă. Microprocesorul este, chiar 
dacă nu cel mai complex, dar în mod cert cel mai reprezentativ element al aces- 
tei lumi. 


Structura de bază a unui microprocesor virtual 


Microprocesoarele nu sînt altceva decît unităţi centrale de calculator (CPU 
— Central Processing Unit). încorporate într-o singură capsulă de circuit inte- 
grat. 

Ele vor citi instrucțiunile unui program dintr-un bloc de memorie, le vor 
decodifica și vor executa comenzile formulate în însuși codul instrucţiunii. 


Fig. 041. 


Vom încerca să umplem treptat blocul funcțional gol din fig. 0.1. cu elemen- 
tele strict necesare pentru funcționarea unei unități centrale, constituind pe 
parcursul prezentului paragraf o posibilă structură de microprocesor. 

Pentru a citi din blocul de memorie externă codul instrucţiunii ce urmează 
a fi executată, microprocesorul va trebui să genereze o adresă pe care o va 
pune la dispoziția memoriei, pînă cînd din celula selectată pe baza acestei adrese 
va apare data cerută. Pentru a putea „,menţține"' starea liniilor de adresă pe durata 
întregii operații de citire, microprocesorul va trebui să posede un element memo- 
rator intermediar, pe care-l vom numi registrul tampon de adrese AB (Address 
Buffer). 

Informâția codificată, citită din memorie o vom depune temporar, de ase- 
menea într-un registru: intermediar. Fie numele acestuia registru tampon de date 
DB (Data Buffer). 

Liniile electrice pe care se va genera cuvîntul binar de adresă le vom numi 
magistrală de adrese ABUS (Address Bus), iar pe cele dedicate datelor citite/ 
scrise în memorie, magistrală de date DBUS (Data Bus). Completînd modelul 
inițial vid, cu aceste elemente, obținem structura din fig. 0.2. 


Fig. 0.2. 


Să presupunem că instrucțiunea recent citită din memorie și depusă temporar 
în registrul de date are următoarea semnificație : „Citește conținutul celulei de 
memorie a .cărei adresă este cu 3 mai mare decît adresa curentă (cea din AB), 
adaugă la această valoare 5 și rescrie rezultatul în aceeași celulă de memorie." 

Pentru a efectua această instrucțiune microprocesorul are nevoie de o unitate 
aritmetică : cu ajutorul acesteia se va putea calcula noua adresă de memorie și 
se va putea efectua adunarea cerută. După cum am amintit deja, în aritmetica 
binară operaţiile aritmetice pot fi descrise cu ajutorul unor funcții logice. Este 
normal ca aceste circuite să fie utilizate și pentru efectuarea unor operaţii logice 
propriu-zise. De aici rezultă și numele utilizat: unitate aritmetică/logică ALU 
(Arithmetic Logic Unit). 

Pentru a putea executa cele formulate în enunţul comenzii, microprocesorul 
va trebui să fie dotat și cu o unitate de comandă. 

Ea este aceea care va disecă problema, „spărgînd-o" în pași elementari și va 
programa execuția secvenţială în timp a tuturor manevrelor necesare pentru a 
duce la bun sfîrșit misiunea ce i-a fost încredințată: generează semnalele de 
comandă pentru întregul sistem, dirijează fluxul de date, corelează viteza de lucru 
a unității centrale cu timpul de acces al memoriei etc. Unitatea de comandă 
poartă diverse nume: CCU — Computer Control Unit, TCU — Timing and 
Control Unit, SQ — SeQuencer sau CC — Command Circuit. Noi vom alege 
ultimul nume. Activitatea unității de comandă este pilotată de un semnal de 
ceas, avînd frecvența de ordinul MHz (1M=10%), 

Semnalele electrice prin care microprocesorul va da comenzi de execuție 
către memorie și celelalte componente din sistem, le vom numi semnale de 
comandă. Semnalele prin care el culege informații privind starea diverselor com- 
ponente din sistem, le vom numi semnale de stare. Întroducînd elementele nou 
definite în modelul considerat, obținem structura din fig, 0.3. 

Să continuăm construcția. Dacă următoarea instrucțiune va folosi rezultatul 
instrucţiunii precedente pentru a efectua o nouă operație aritmetică, atunci 
valoarea calculată în prealabil trebuie citită din nou din memorie. Acest acces 
suplimentar la memorie poate fi economisit, dacă în interiorul microprocesorului 
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Fig. 03. 


vom prevedea cîteva elemente de memorare în care să se poată înmagazina tem- 
porar date sau adrese de memorie. Aceste elemente de memorie ale microproce- 
sorului le vom numi regiştri. Unii din acești regiștri vor fi folosiți în scopuri 
dedicate, cum ar fi urmărirea execuției secvențiale a instrucțiunilor din memorie. 
Registrul tampon de adrese (AB) nu poate fi folosit în acest scop, fiindcă așa 
cum s-a văzut în exemplele prezentate, conținutul lui va trebui să se modifice, 
eventual de mai multe ori pe parcursul execuției unei instrucțiuni (cazul în care 
instrucțiunea în curs trebuie să efectueze accese la memorie, pentru a citi sau 
a scrie date în ea). Este deci nevoie de un registru în care să se poată genera 
şi păstra nealterată adresa de memorie a următoarei instrucțiuni de executat. 
Folosind acest registru, microprocesorul va putea continua — după terminarea 
instrucţiunii în curs — execuția secvenţei de instrucțiuni prevăzute, care astfel 
se constituie într-un program. 

Numele acestui registru special este contor de program PC (Program Counter). 

Într-un alt registru special vom putea păstra informaţii referitoare la natura 
rezultatului unei operații aritmetice : număr negativ sau pozitiv (eventual egal 
cu zero), număr par sau impar etc. În acest registru, fiecărui atribut considerat 
i se va rezerva un bit. Vom numi acești biți, biți de condiţie, iar registrul îl vom 
numi registrul indicatorilor de condiţie F (Flag — steguleț, fanion). Avem nevoie 
de acest registru pentru a putea defini instrucțiuni de salt condiționat. Să ne 
imaginăm următoarea instrucțiune : „Dacă rezultatul operaţiei precedente este 
un număr negativ, atunci continuă execuția programului cu instrucțiunea locată 
la adresa de memorie următoare (valoarea actuală a contorului de program, PC); 
dacă numărul este pozitiv, continuă execuţia la adresa egală cu valoarea conți- 
nută în primul registru de uz general”'. Această instrucțiune va verifica valoarea 
„indicatorului de semn”! și va ramifica execuția programului în funcție de valoarea 
acestui bit. 

Să introducem și regiștri în schema bloc din fig. 0.3. Cu aceasta putem con- 
sidera încheiată definirea principalelor structuri funcționale ale microprocesorului. 

Pentru efectuarea transferurilor interne de date, microprocesorul va fi pre- 
văzut și cu o magistrală internă de date, magistrală a cărei „lățime”' (număr de 
linii distincte) depinde de tipul microprocesorului în cauză. 


Privind din exterior, la terminalele microprocesorului regăsim semnalele sale 
de comunicaţie cu sistemul constituit în jurul lui : magistrala de adrese, magis- 
trala de date și magistrala de comenzi. 

La magistralele de date și de comenzi pot fi cuplate circuite de intrare/ieșire 
(1/0) care stabilesc legătura cu lumea externă : interfața om-mașină și accesul 
la memorii de masă, nevolatile. Dacă veți completa fig. 0.4 cu cîteva dispozitive 
de intrare/ieșire, veţi obține schema bloc a hardware-ului minimal al unui micro- 
calculator, 

Ideea de magistrală unică, „„plimbată”” la toate elementele funcționale din 
sistem — inclusiv la cele de intrare/ieșire — este o caracteristică constructivă 
de bază a microcalculatoarelor. Amintim aici, că unitățile de calcul mai perfor- 
mante efectuează operaţiile de intrare/ieșire prin așa numitele canale de 1/O, 
a căror complexitate „poate depăși uneori complexitatea unui microcalculator. 
Ele sînt capabile să efectueze transferul de date între calculator și mediul extern 
în mod independent, fără ca prin aceasta să perturbe cîtuși de puțin derularea 
unui program de către unitatea centrală, 

„Lungimea”' (numărul de bit a regiștrilor interni ai microprocesorului) se 
corelează de obicei cu „„lățimea”' (numărul de linii) ale magistralei de date. Aceasta 
este măsura „numărului de biți'' ai unui microprocesor, Microprocesoarele cu 
structură fixă sînt de obicei de 8, 16 sau 32 bit. Lungimea de cuvînt a micro- 
calculatoarelor realizate cu microprocesoarele „bit slice” (felii de bit), a căror 
structură este flexibilă, va fi totdeauna un multiplu întreg al numărului de bit 
al unei felii. 

Registrul de adresă, respectiv „„lățimea”' magistralei de adrese definește spa- 
țiul de memorie adresabil direct de către microprocesor. O magistrală de adrese 
de 16 bit permite adresarea a 21%=—65536 celule de memorie distincte, iar 20 de 
iai de adresă ne conduc în lumea megaocteților : 220 = 1.048.576 celule adre- 
sabile. 


Z80 este un microprocesor pe 8 bit, cu 16 linii de adresă, 


0.3. Numere binare și reprezentarea lor hexazecimală 


În interiorul calculatoarelor toate informaţiile sînt reprezentate sub forma 
unor numere binare, sau sub forma unor grupe de bit. 

Cuvîntul bit derivă din binary digit (cifră binară). Bitul este unitatea de 
măsură de bază în orice sistem informaţional binar și poate avea două valori 
distincte : O și 1. O grupă de 8 bit se numește octet sau byte. O grupă de 4 
bit se numește nibble. 

În continuare, ne vom referi la numere binare reprezentate pe 8 bit, speci- 
ficînd faptul că exemplele pe care le vom prezenta vor putea fi ușor extinse 
pe numere cu număr mai mare de bit. 

Numerele binare se reprezintă sub forma unui șir de O și 1. 


Poziţiile cifrelor binare le vom numerota cu b, —b,: 
b be bs be ba ba b, bo 
b, reprezintă bitul (cifră binară) cel mai semnificativ iar b, bitul cel mai 


puțin semnificativ al octetului. 
Valoarea unui octet se poate calcula cu expresia 


b,.274+b,:-2%+4+b,.25+b,:-2%+4+b,:23+b,:.22+b,:2'1+b,.:20 
Puterile lui 2 sînt: 
27=—128, 25——=64, 25=—32, 24=—16, 23=—8, 22—4, 21=—2, 29=1 


Ați remarcat desigur faptul că reprezentarea binară a numerelor respectă 
aceleași reguli ca și cea larg răspîndită, cea zecimală. 

Numărul zecimal 217 nu este altceva decît reprezentarea compactă a urmă- 
torului șir de operații : 


2.102 + 1.10 + 7.100 = 200 + 10 +7 
Numărul binar 1101 1001 
este de fapt 
27 + 25 + 24 4+ 23 + 1 = 217 


În mod similar se pot defini diverse sisteme de reprezentare a numerelor, 
folosind ca bază de numărare orice număr mai mic sau mai mare ca 10. Pentru 
a ne putea familiariza ușor cu gîndul unui nou sistem de numărare trebuie să 
pornim de la convingerea că sistemul zecimal nu este altceva decît o cimentare 
profundă în creierele noastre, născută și întărită de-a lungul mileniilor, numai 
şi numai datorită faptului că omul are zece degete. Dacă omul n-ar fi avut 
degete, ci doar două miini, atunci mai mult ca probabil, astăzi sistemul binar ar 
fi cel „implementat” în sistemul nostru nervos. 

Cert este că ne putem considera norocoşi, căci memorarea și redarea (sub 
formă scrisă sau orală) a numerelor binare pare să fie și un exercițiu de răbdare, 
De aceea în reprezentarea externă calculatorului, numerele binare vor fi speci- 
ficate de obicei într-un alt sistem de numerație, mai compact, dar care să se 
muleze bine peste organizarea bit-nibble-byte a numerelor binare vehiculate în 
calculatoare. 
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Sistemul cel mai potrivit s-a dovedit a fi cel hexazecimal, cel care admite 
șaisprezece cifre distincte. Cifrele propriu-zise (zecimale) se dovedesc a fi insu- 
ficiente. De aceea le vom completa cu litere. lată deci cifrele sistemului hexa- 
zecimal : 0, 1,2, 3, 4,5,6,7,8,9, A,B,C,D,E,F. 

Grupajul 10 reprezintă, ca în toate sistemele de numerație de altfel, baza 
sistemului hexazecimal. 


(10 = 160; 108 = 2p; 10p = „zece”) 


Folosind cifrele hexazecimale, fiecare octet binar poate fi exprimat prin 


două cifre. 

Aceasta este forma sub care vorbim și scriem despre numerele binare din 
interiorul calculatoarelor, o punte între structura gîndirii umane și cea a cal- 
culatoarelor. 

În tab. 0.1 redăm tabela de echivalență a primelor șaptesprezece valori nume- 
rice ale sistemelor de numere zecimal, hexazecimal, binar, și octal. Ultima coloană 
este redată ca fapt divers : 


Tabelul 0.1. 

zecimal hexa binar octal 
[9) 0 0000 0 
1 1 0001 1 
2 2 0010 2 
3 3 0011 3 
4 4 0100 4 
5 5 0101 5 
6 6 0110 6 
/ d, 0111 4 
8 8 1000 10 
9 9 1001 11 
10 A 1010 12 
11 B 1011 13 
12 G 1100 14 
13 D 1101 15 
14 E 1110 16 
15 F 1111 17 
16 10 10000 20 


Asupra operațiilor aritmetice în sistemul binar,precum și asupra reprezentării 
numerelor binare cu semn,vom reveni în capitolul următor. 

Cunoscînd reprezentarea externă (cea hexazecimală) veți putea să discrimi- 
nați ușor două numere aparent identice 11011011 și 11001101, care tratate drept 
coduri de instrucțiuni, declanșează activități total diferite în lumea internă a 
microprocesorului Z80. (Primul DB este codul instrucţiunii de citire de la peri- 
ferice, iar al doilea CDy apelează o subrutină). 


0.3. NUMERE BINARE 11 


Înainte de a ne duce cu sacul la pomul lăudat, să vedem ce ne oferă la 
prima vedere programul VISIBLE—Z80. Pentru aceasta cititorul trebuie să par- 
curgă şi secțiunea A din partea a l-a a lucrării „,COMPLEMENTE". (pag. 233) 

Vom desena cu ajutorul calculatorului PRAE sau aMIC, acționat de caseta 
cu programul VISIBLE—Z80, structura internă a microprocesorului Z80, structură 
organizată pe blocuri funcționale. 

lat-o : 


[2] 
Sau 
ST EŞDI CEPE IE TRACE FAST 


E ERE a Ru Da 
eee lee] 7] 


[.] 
29000e1 a 
aoâece1ă 

L SR 
AES 


i a.L.u. ie 


NAT ea 
MREG IX 9900 
mere COMMAND lY 9098 
pi R CIRCUIT SF 7F09 
Buza PC _aoca 
RESET 

= oa U 

rii HE 200098 


Im.O 


În Im.O regăsim concentrate toate structurile funcționale pe care le-am 
inserat treptat în modelul microprocesorului teoretic constituit în PRAELUDIUM 
(vezi fig. 0.4). 
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În partea din stînga sus apare un cîmp de comentarii, menit să informeze 
utilizatorul asupra numelui și codului instrucţiunii ce se execută, precum şi 
adresa de memorie la care se află ea stocată (MNE, COD și ADR). În căsuţele 
notate cu T și CM primim detalii privind faza în care a ajuns execuția instruc- 
ţiunii studiate. Ce anume sînt ciclurile de tact și cele mașină, vom vedea peste 
50 pagini în paragraful 4.1. În extremitatea superioară a Im. O se observă 
o bară orizontală (SPEED) divizată în 23 de porțiuni egale, marcate din loc în 
loc cu simboluri (CC, MC, IC, TRACE, FAST). Deasupra acestei bare se poate 
deplasa un cursor, (o linie orizontală mai groasă) care indică pe scara gradată 
a barei de viteză (SPEED) regimul de lucru şi viteza de simulare ale programului 
de instruire VISIBLE—Z80. 


Facem abstracție de existența acestor elemente grafice, ele nefiind părți 
componente ale microprocesorului, ci doar comentarii. Le vom folosi mai încolo, 
pentru a ne ghida pe drumurile accidentate ale celor zece aventuri pe care le 
vom întreprinde în „interiorul”' microprocesorului Z80, în speranța neascunsă 
de a descifra majoritatea tainelor acestui circuit integrat. 


În extremitatea laterală dreaptă a Im. O apare o căsuță notată MEMO, 
care simbolizează un bloc de memorie de lucru, fără de care nu se poate aborda 
prezentarea funcționării nici unei unități centrale. Nici acest modul nu este o 
parte componentă a microprocesorului luat în studiu. Microprocesorul „se termină” 
de fapt la cei doi regiștri tampon : registrul tampon pentru date (DB-data buffer) 
și registrul tampon pentru adrese (AB — address buffer). 

Ne oprim aici cu eliminările, înainte de a-i crea cititorului impresia că dorim 
să reducem structura microprocesorului la un pătrățel mic și cenușiu (așa cum 
ea este de fapt în realitate), despre care oricum nu se poate spune mai 
nimic ! 

Rămîn deci regiștrii speciali și cei de uz general (AB, PC, SP, IY, IX, R,I,W, 
Z,H', L',D',E*,B',C',H,L,D,E,B,C,A,A"F,F',T,T şi IR), circuitul de co- 
mandă (Command Circuit), unitatea aritmetică și logică (ALU) magistralele 
interne și semnalele externe (INT, NMI, M1, MREQ, IORQ, RD, WR, BUSRQ, 
BUSAK, RESET, HALT, RFSH şi WAIT). 

Să le cunoaștem pe rînd, nu înainte de a preciza faptul că structura generată 
de VISIBLE— Z80, așa cum se vede și în Im. O, este o structură minimă care ținînd 
cont de posibilitățile grafice limitate (256 x 256 de puncte) ale calculatoarelor 
personale PRAE și a MIC încearcă să prezinte totuși modulele de importanță 
vitală, fără care prezentarea funcționării microprocesorului ar putea duce la inter- 
pretări ambigue. Oricum, apar cîteva elemente suplimentare față de modelele 
care s-au publicat pînă în prezent în literatura de specialitate, pe care le-am 
considerat însă absolut necesare (de exemplu, al doilea registru T). 


Pentru a putea funcționa, executînd programe stocate într-un modul de memo- 
rie, precum și pentru a avea un număr oarecare de date disponibile imediat, 
în interiorul fiecărui microprocesor se înglobează cîteva celule de memorare, 
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celule a căror conținut poate fi citit, modificat și rescris în caz de nevoie. Aceste 

celule de memorie de tip citește/scrie, încorporate în interiorul microprocesorului 

se numesc regiştri. Așa cum ne sugerează amplasarea și forma de reprezentare a 

acestor regiștri în Ilm.O, ei nu sînt toți identici. Unii sînt mai scurți (8 bit), 

alții au lungime dublă (16 bit), la unii am reprezentat fiecare bit în parte (F 

și F”) fiindcă ei au o semnificaţie aparte, la alții această discriminare nu este nece- 

sară. În Im. O se observă că fiecărui registru îi este atașată o căsuță în care se 
înscrie și valoarea hexazecimală a numărului pe care el îl conține. (Faptul că în 
această stare inițială conținutul majorității regiștrilor este 0, este o pură întîm- 
plare). 

Dacă dorim să clasificăm regiștrii, trei este numărul criteriilor mai des folo- 
site : 

— lungimea (numărul de bit): distingem regiștri de 8 bit (A,B,C etc.) și de 
16 bit (PC, SP etc.) 

— accesibilitatea : pe lîngă regiștri accesibili utilizatorului prin instrucțiuni spe- 
cifice, există cîțiva regiștri de manevră care se folosesc pentru stocarea 
temporară a unor date, regiștri care sînt transparenți utilizatorului (ex. 
T, DB, AB etc.) 

— destinaţia : există regiștri de uz general care se folosesc ca simple celule de 
memorie internă și alții cu destinaţie specială care, pe lîngă trăsătura de 
memorare, fie că sînt dedicați stocării doar a unui anumit tip de date 
(PC, IR, F), fie că sînt înzestrați și cu anumite facilități suplimentare 
(SP, A etc.). 

Vom începe prezentarea regiștrilor grupîndu-i după ultimul criteriu. 


1.1.1. Regiştri speciali 


Contorul program — PC (Program Counter) este un registru dublu, avînd 
lungimea de 16 bit. El este destinat să memoreze adresa instrucţiunii ce urmează 
a fi executată. După ce se citește codul instrucţiunii curente din memorie (ope- 
rația fetch), conținutul acestui registru este incrementat automat cu 1. Astfel se 
asigură secvenţialitatea în execuția unui șir de instrucțiuni (program). Instruc- 
țiunile se vor executa începînd de la adresa 0, în ordinea crescătoare a adreselor. 
Există și instrucțiuni de salt, care înscriu direct conținutul registrului PC cu o 
valoare dorită de programator. Astfel pot fi executate programe a căror adresă 
de început diferă de 0 și se pot executa ramificații în program, în funcție de 
rezultatul unor calcule, sau a unor evenimente externe detectate prin program 
(salturi condiționate). Memoria adresabilă direct este de 216 = 65536 locații de 
memorie distincte. Spațiul de adrese este deci 0000—FFFF în sistem hexazecimal. 

Indicatorul de stivă — SP (Stack Pointer) este un registru dublu, avînd lun- 
gimea de 16 bit. SP este un registru de adresare special. Avînd aceeași lungime 

„ca și PC, el poate adresa întregul spațiu de adrese de memorie : 0000 —FFFF 
Pentru a înțelege mai bine menirea lui, trebuie să facem o mică paranteză. 

Stim că numărul regiștrilor interni ai microprocesorului este limitat și, impli- 
cit, și cel al datelor ce se pot înmagazina în ei. În cursul elaborării unor programe 
scrise în limbaj de asamblare, apare frecvent necesitatea de a elibera unul sau 
mai mulţi regiștri pentru ca în ei să se poată înmagazina temporar noi date. Nedo- 
rind să pierdem informaţia precedentă din regiștrii respectivi, îi vom salva în 
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memoria externă RAM (Random Access Memory), care fiind o memorie de tip 
scrie/citeşte permite să restaurăm în regiştri oricînd valorile eliminate temporar. 
Se pune întrebarea: unde anume să salvăm aceste date, la ce adresă? Dificul- 
tatea derivă din două surse: pe de o parte, dacă am dori să efectuăm aceste 
salvări la adrese de memorie nominalizate, s-ar putea să fim nevoiți să memorăm 
la un moment dat zeci de adrese de memorie, și semnificația fiecăreia (ce con- 
ține celula respectivă) fapt care ar îngreuna considerabil munca de programare. 
Pe de altă parte, se știe că de la John von Neumann încoace în memoria RAM 
poate rezida şi programul executat. Dacă se execută salvări repetate ale regiș- 
trilor se poate ivi la un moment dat un conflict: valorile salvate riscă să se 
suprapună peste program, lezîndu-l, ceea ce trebuie să recunoaștem, ar fi o 
eroare fatală. Pentru a se depăși inconvenientele prezentate, s-a convenit ca anu- 
mite zone de memorie să aibă o organizare specială, reglementîndu-se acceptul 
la ele (adresarea) pe baza unor reguli universal valabile și simple. Se va folosi 
un indicator de adresă care la fiecare salvare de registru (scriere în memorie) va 
avansa automat, indicînd adresa următoarei celule libere. La restaurarea conținu- 
tului registrului dorit (citire din memorie) indicatorul de adresă se va repozi- 
ționa automat, indicînd adresa de memorie a penultimei date salvate. O zonă 
de memorie astfel organizată se numește stivă. Legea de bază care guvernează 
mișcarea de date în această zonă se numește: LIFO (Last In First Out), adică 
ultimul intrat este primul care pleacă. Legea este simplă și o cunoaștem cu 
toții. 
Observăm că dacă există un registru de adresă prevăzut cu automatul de 
incrementare/decrementare la operaţiile de scriere și citire memorie, atunci el 
poate controla în mod univoc toate activitățile de salvare /restaurare în stivă. Rezultă 
deci, că stiva poate fi organizată oriunde într-o memorie de tip scrie/citește (RAM). 
Registrul de adresare al stivei se numeşte indicator de stivă. La majoritatea 
microprocesoarelor stiva este descrescătoare : salvările (scrierile) succesive se fac 
la adrese descrescătoare. S-a ales această variantă pornind de la faptul că con- 
torul program FC variază crescător. Programele locate în memorie încep de la 
adresa CCCO și cresc spre 2drese superioare. Pentru a nu se disloca mereu zona 
de stivă, în mășura în care lungimea programelor variază, este convenabil ca 
indicatorul de stivă să fie inițializat astfel încît să ponteze (adreseze) sfîrşitul 
memoriei RAM, de unide va descrește la salvări. O altă soluție de separare a zonei 
program de zona de stivă este aceea de a amplasa stiva la adresa imediat infe- 
rioară începutului de program. Și în acest caz avem nevoie de o stivă descres- 
cătoare. 

La microprocesorul Z80, registrul SP organizează o stivă descrescătoare : la 
fiecare salvare se înscriu în memorie 2 octeți (2 regiștri simpli sau 1 registru 
dublu) și conţinutul indicatorului de stivă este decrementat cu 2. 


SP = SsP—2 
La fiecare restaurare se citesc din memorie 2 octeți și conţinutul indicato- 
rului de stivă este incrementat cu 2. 
SP = SP+2 


Pentru salvarea și restaurarea datelor din regiștri, stiva se dovedește afi 
foarte utilă și convenabilă, dar nu și de neînlocuit. Există în schimb un caz în 
care existența unei memorii organizată ca stivă este imperios necesară, și anume : 
la apelarea subrutinelor și mai ales în cazul unor apeluri multiple. 
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Ori de cîte ori programatorul scție anumite module care pot fi folosite fn 
mai multe puncte ale programului său, el le va scrie sub formă de subrutine. 
O subrutină poate fi oricînd apelată dintr-un program principal, folosind o instruc- 
țiune de tipul CALL adresă, unde adresă este adresa de început a subrutinei. La 
întîlnirea unei instrucțiuni CALL secvența de execuție a programului principal 
este abandonată, se execută subrutina, iar la întîlnirea unei instrucțiuni de tipul 
RET, care marchează sfîrșitul subrutinei, se revine în programul apelant, la instruc- 
țiunea imediat următoare instrucţiunii CALL. Cum se revine? 

Odată cu executarea instrucţiunii CALL, adresa instrucţiunii următoare din 
programul apelant este salvată în vîrful stivei, iar la execuția instrucţiunii RET 
această valoare este citită din vîrful stivei și încărcată în contorul -program PC, 
reluîndu-se astfel „firul pierdut”. La citirea acestei pledoarii pentru necesitatea 
imperioasă a indicatorului de stivă SP, oricine și-ar putea pune întrebarea: nu 
s-ar fi putut folosi un registru tampon, dedicat pentru salvarea adresei de reve- 
nire în programul apelant ? S-ar fi putut, da! Dar ce ne facem, dacă dintr-o 
subrutină dorim să apelăm o altă subrutină, și așa mai departe ? Pentru fiecare 
nivel de întreţesere în apelarea subrutinelor ar fi necesar cîte un registru supli- 
mentar pentru memorarea tuturor adreselor de revenire. În istoria microproce- 
soarelor se cunoaște și această soluție. Primul microprocesor pe 8 bit, micro- 
procesorul 18008 al firmei INTEL, avea 8 regiștri interni pentru memorarea 
adreselor de revenire. S-a și renunțat la această idee, deja la următorul 
microprocesor, 18080 al aceleiași firme. Soluţia inițială s-a dovedit a fi neavanta- 
joasă, fiindcă limita nivelul de întrețesere a subrutinelor la 8 şi consuma toto- 
dată o cantitate considerabilă din resursele hardware interne ale microproce- 
sorului. lată de ce un indicator de stivă care să permită organizarea unei zone 


de stivă în memoria RAM, externă microprocesorului, este într-adevăr indis- 
pensabil. 


Atragem de pe acuma atenţia cititorului că folosirea acestui registru este 
delicată. Pe stivă se înmagazinează atît valori salvate din regiștri de date, cit și 
adrese de revenire din subrutine. Vă daţi seama ce se întîmplă dacă dintr-o 
eroare de programare, la revenirea dintr-o subrutină în contorul program PC 
se încarcă o dată oarecare și nu adresa de revenire! Pentru eliminarea acestui 
inconvenient la microprocesoarele mai evoluate există doi sau mai mulţi indicatori 
de stivă, putîndu-se organiza astfel stive separate pentru date și pentru adrese 
de revenire din subrutine. Pînă una alta, specialiștii firmei Zilog au păstrat un 
singur indicator de stivă pentru microprocesorul Z80. Așa vom face și noi. 


Registrul de instrucțiune — IR (Instruction Register) este un registru special 
cu lungimea de 8 bit. Aceasta este celula în care se depozitează codul unei instruc- 
țiuni, citit din memorie la operaţia fetch. Circuitul de comandă al microproceso- 
sului preia codul instrucţiunii de executat din IR, îl decodifică și își programează 
toate activitățile pe care le are de efectuat în vederea ducerii la bun. sfîrșit a 
„„poruncii”” primite. Programatorul nu are acces în mod explicit la acest registru. 


Registrul A (Acumulator) — este un registru avînd lungimea de 8 bit. El 
se distinge prin faptul că pe lîngă a ști să memoreze un octet, este implicat în 
toate operaţiile aritmetice și logice : unul din cei doi parametri asupra cărora 
urmează să fie efectuată o operaţie aritmetică sau logică (adunare, scădere, etc.) 
se va afla obligatoriu în acumulator. Rezultatul operaţiei se generează de asemenea 
în registrul A, el suprascriindu-se peste valoarea inițială. Observăm că operațiile 
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aritmetice și cele logice acționează astfel încît acumulează rezultatele în registrul 
A. De aici provine și numele de acumulator. Ne putem imagina un microprocesor 
virtual care să aibă mai mulți regiștri prevăzuţi cu această facilitate specială. Acel 
microprocesor ar avea mai mulți acumulatori. S-au realizat și astfel de micropro- 
cesoare. Un exemplu în acest sens îl poate constitui microprocesorul M6800 al 
firmei Motorola. Conchidem prin a afirma că a poseda mai mulți acumulatori 
poate fi un avantaj, reducîndu-se astfel numărul de manevre necesare „pentru efec- 
tuarea unor operaţii aritmetice/logice, dar este cert : un singur acumulator este 
suficient pentru a efectua operații oricît de complexe. Totul depinde de califi- 
carea profesională și iscusința programatorului în a aranja operaţiile elementare 
ale microprocesorului într-o ordine dorită, astfel ca programul realizat să efec- 
tueze într-adevăr ceea ce dorim. 


În Im. O remarcăm prezența unei căsuțe marcate cu simbolul A”. Acest 
registru este un registru secundar, care împreună cu regiștrii F*, B', C',D',E",H' 
şi L” formează grupul regiștrilor secundari. Existența acestor regiștri secundari 
este o particularitate a microprocesorului Z80. Ei sporesc considerabil performan- 
țele lui Z80 în comparație cu predecesorul său 18080. Conţinutul registrului A” 
poate fi interschimbat cu cel al registrului A, folosind instrucțiunea EX. AF, AF”. 
A” nu este un al doilea acumulator al microprocesorului Z80 fiindcă doar unul, 
anume A, poate fi activ la un moment dat. Toate instrucțiunile microprocesorului 
afectează conținutul acumulatorului primar A. 


Registrul indicatorilor de condiție — F (Flag). Așa cum o spune și numele 
simbolic ales pentru acest registru special (flag-fanion, steguleţ) el este menit să 
semnaleze ceva. În acest registru, care în cazul microprocesorului Z80 are lun- 
gimea de 8 bit, fiecare bit în parte are semnificaţia lui. Starea lor (0 sau 1) 
indică satisfacerea sau nesatisfacerea unor condiții date. De aceea ei se numesc 
indicatori de condiție. Flagurile furnizează atît programatorului cît și însăși uni- 
tății de comandă a microprocesorului, informații privind natura rezultatului unei 
operaţii aritmetice sau logice efectuate. Din starea biților dedicați ai registrului 
F putem afla dacă rezultatul operației efectuate este O sau nu, dacă el este un 
număr pozitiv sau negativ, dacă numărul biților din rezultat ce au valoarea 1 
este un număr par sau impar etc. 

Să-i privim pe rînd: 


e Flagul S (sign=semn) care apare pe poziția cea mai semnificativă a regis- 
trului F. (bit 7), memorează bitul cel mai semnificativ al unui număr rezultat 
pe baza unei operaţii aritmetice sau logice, în acumulator. . În reprezentarea binară 
a numerelor, bitul cel mai semnificativ se folosește adesea pentru indicarea sem- 
nului unui număr. Prin convenție, și rezultînd din particularitățile reprezentării 
sub forma complementului față de 2 a numerelor binare, valoarea 0 a bitului 
cel mai semnificativ indică număr pozitiv, iar valoarea 1 un număr negativ. Înzes- 
trînd bitul cel mai semnificativ al unui număr binar avînd lungimea de?n bit, cu 
funcţia de semn, totalul numerelor reprezentabile prin acel număr nu se schimbă. 
Se modifică însă plaja de reprezentare a lor. Dacă se folosește convenția nume- 
relor întregi fără semn, atunci un număr binar de 8 bit poate avea 2% = 256 de 
valori distincte, cuprinse în plaja [0,255]. Dacă convenţia de reprezentare este: 
numere întregi cu 'semn, atunci aceeiași 8 bit pot reprezenta deasemenea 256 de 
valori, cuprinse de data aceasta în plaja [—128, +127]. În tehnica de programare. 
a microprocesoarelor, rămîne pe seama programatorului să decidă asupra semni- 
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ficaţiei bitului celui mai semnificativ și implicit al flagului de semn S$. Starea 
flagului S poate fi testată de către programator prin două instrucțiuni de salt 
condiționat : JP P, nn și JP M, nn care permit ramificarea programului în funcţie 
de starea indicatorului de semn. 


JP P,nn (jump if plus)  — salt dacă pozitiv, efectuează saltul la adresa nn, 
dacă S=0; 

JP M,nn (jump if minus) — salt dacă negativ, efectuează saltul la adresa nn, 
dacă S=1. 


Vom vedea mai încolo că există și alte instrucțiuni prin care se poate testa flagul 
S, ca și flagurile Z,P/V, și Cy de altfel, dar ne limităm deocamdată la aceste 
două, fiindcă ele ilustrează destul de sugestiv utilitatea indicatorilor de condiţie. 

e Flagul-Z (zero) — apare pe poziția bit 6 a registrului F. El este înscris 
(valoarea 1), dacă rezultatul unei operaţii aritmetice/logice este 0. Dacă rezul- 
tatul operaţiei diferă de 0, atunci conținutul indicatorului Z va fi 0. Ca şi S, 
flagul Z poate fi testat de către programator prin instrucțiunile de salt condi- 
ționat : JP NZ,nn ; JP Z,nn unde: 

JP NZ,nn (jump if not zero) semnifică salt, dacă diferit de zero : saltul se efec- 
tuează dacă Z=0; : 

JP Z,nn (jump if zero) înseamnă salt, dacă zero : saltul se efectuează dacă Z=1. 
Acest indicator este folosit și de către circuitul de comandă al microprocesoru- 
lui, la execuția unor instrucțiuni repetitive. Amintim instrucţiunile de comparaţie 
CPDR și CPIR (compare increment repeat respectiv decrement...) caz în care 
instrucțiunea care compară conţinutul acumulatorului cu celule de memorie aflate 
la adrese crescătoare (sau descrescătoare) se termină dacă Z=1, adică în cazul 
egalității celor două numere comparate. Instrucţiunile de transfer de blocuri de 
date la periferice, INDR și INIR precum și OTDR și OTIR se termină deaseme- 
nea în cazul în care Z=1 (conţinutul registrului B devine 0). 

9 Flagul H (Half carry) reprezintă transportul care apare în cursul unei ope- 
raţii aritmetice de la bit 3 spre bit 4 al acumulatorului. El ocupă poziţia bit 4 
în registrul indicatorilor de condiție F. Flagul H nu poate fi testat prin instruc- 
ţiuni de salt condiționat. El este folosit de către unitatea aritmetică/logică a 
microprocesorului (ALU), la execuţia instrucţiunii de corecție zecimală (DAA — 
Decimal Adjust Acumulator), pentru corecția numerelor zecimale codificate binar : 
BCD. Dacă considerăm cei 4 biţi inferiori (bit O — bit 3) ai unui număr cao 
cifră hexazecimală (digit), care poate avea valori în domeniul [0 — FI], transportul 
intermediar H va fi închis (va avea valoarea 1) ori de cîte ori, ca rezultat a unei 
operații de adunare sau scădere, valoarea digitului mai puțin semnificativ (bit O 
— bit 3) depășește domeniul : fie că ar trebui să fie mai mare de Ș, fie că ar 
trebui să fie negativ (mai mic ca zero). ALU execută toate operațiile în sistemul 
binar. De aceea, pentru a putea lucra și cu numere zecimale codificate în binar 
(BCD), instrucțiunea de ajustare a rezultatului unei operaţii aritmetice DAA, 
va folosi acest bit de transport intermediar. * 


6 Flagul P/V (Parity/Overflow) — este un indicator de condiție multifunc- 
ţional. El ocupă poziția bit 2 în registrul F. Așa cum rezultă din numele acestui 
indicator, el poate indica paritatea numărului din acumulator sau depășire de 
domeniu. O a treia funcție a acestui flag este citată destul de rar în literatura 
de specialitate (ea dezvăluindu-se doar celor care studiază atent setul de instruc- 
țiuni al microprocesorului) : instrucțiunile de transfer multiple (LDD, LDI, LDDR, 
LDIR) și cele logice multiple (CPD, CPI, CPDR, CPIR) utilizează flagul P/V 
ca detector de zero al registrului dublu BC. În acest din urmă caz P!V=0, dacă 
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conținutul registrului dublu BC=0, ceea ce este o condiție de terminare a instruc- 
țiunilor cu repetiție. Pentru aceste instrucțiuni P/V=1 dacă BCz0. 
Dar să revenim la funcțiile de bază ale indicatorului P/V. 


Paritatea 

Una din procedeele de verificare a corectitudinii transferurilor de date intra-și 
intercalculator este cea care atașează celor n biţi utili de date un bit suplimentar 
de control. Acest bit se alege astfel încît suma cifrelor 1 din totalul celor n+1 
biți transferați să satisfacă criteriul de paritate ales : paritate pară (even) — suma 
cifrelor de 1 este un număr par; paritate impară (odd) — suma cifrelor de 1 
este un număr impar. Nu încape îndoială că oricine ar putea concepe un program 
scurt care să calculeze paritatea. Sîntem însă scutiți de acest efort, datorită existen- 
ței flagului P/Y care în anumite condiții (vom vedea care) indică tocmai paritatea 
numărului binar din acumulator. Atunci cînd P/V indică paritatea el are urmă- 
toarele valori : 

P/V=0 dacă totalul cifrelor 1 din A este un număr impar; 

P/V=1 dacă totalul cifrelor 1 din A este un număr par. 


Depășirea 

Pentru a înțelege mai bine noțiunea de depășire și rolul indicatorului P/V 
în mod de depășire, trebuie să ne întoarcem la reprezentarea numerelor binare 
cu semn : bitul cel mai semnificativ, bit 7 (în cazul microprocesoarelor pe 8 biţi) 
este bit de.semn. Folosind pentru numere negative reprezentarea în complementul 
față de 2, avem: 


0000 0000 — 00, — 0 
0114 1111 — 7Fu = k+127 
1000 0000 — 80, — —128 
1111 1111 — FF — 1 


Numim depășire fenomenul prin care rezultatul unei operaţii aritmetice depă- 
șește domeniul [—128, 4+127]. 
Dar de unde aflăm, dacă avînd un rezultat de 


1000 1111 


el reprezintă : a) numărul —113 (încadrat în domeniu) 

sau ; b) numărul 4-143—128415 (depășind domeniul de valori)? 
Pentru a putea fi siguri de corectitudinea rezultatului, ar trebui să analizăm cele 
2 numere implicate în operaţia aritmetică efectuată, și astfel am putea prezice 
dacă se va depăși domeniul de valori sau nu. 

Regimul de „,depășire” al indicatorului P/V ne scutește de această antecalculație. 
Dar cum ? Vom încerca să stabilim o procedură, ușor implementabilă, pentru a 
vedea modul de funcționare a flagului P/V. 


Exemplul 1: 
bit: 76543210 adică : 
nr. 1:01011111 + +95+ 
nr. 2: 01100011 +99 
rez.: 11000010 194 
transp.: 1111111 
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Comparînd rezultatul adunării binare (11000010=——62) cu cel al operaţiei zeci- 
male (4194) observăm că rezultatul binar diferă de cel zecimal, fiind deci inco- 
rect. Analizînd faptul că am adunat două numere pozitive 495 și 499 și am 
obținut un număr negativ —62, eroarea o atribuim depășirii domeniului de valori. 
Eroarea se datorește existenţei unui transport de la bit 6 la bit 7 (bitul de semn). 
„Această depășire trebuie! detectată, pentru ca rezultatul să poată fi corectat. 


Li 


Exemplul 2: 
bit: 76543210 adică : 
nr. 1:11111100+ —4+ 
nr. 2:11111110 —2 
rez.: 111111 —6 
transp.: 111111 
adică —6 — corect. 


Observăm că și în acest caz apare un transport de la bit 6 la bit 7, dar acesta 
nu afectează corectitudinea rezultatului, deoarece atît cele două numere adunate, 
cît și cel rezultat au semnul negativ. Observăm în schimb, că apare spre deose- 
bire de primul caz și un transport de la bit 7 în sus (acest transport se numește 
pe obicei carry). 


Exemplul n 


bit: 76543210 adică : 

nr. 1:11010110 + —42+ 
nr. 2:10011111 —97 
rez.: 01 110101 —139 
transp.: î 1111 

adică : +117 — incorect. 


În acest caz numărul. rezultat: din adunarea binară a două numere negative este 
un număr pozitiv, ceea ce desigur este incorect. În acest caz nu a existat transport 
de la bit 6 la bit 7, dar a apărut un transport de la bit 7 în sus (carry). 


Exemplul 4: 
bit: 76543210 adică : 
nr. 1:10101111+ —814+ 
nr. 2:01100110 102 
rez.: 00010101 +21 
transp.: 111 111 


adică : +21 i corect. O 


Observăm că. și în acest caz rezultatul adunării binare este corect. A existat 
transport atît de la bit 6 spre bit 7 cît și de la bit 7 în sus. 

Din cele patru exemple putem să tragem concluzia că rezultatul operaţiei arit- 
metice este corect, dacă apare concomitent transport către bitul de semn și de 
la el în sus. Dacă apare numai unul din aceste transporturi, atunci rezultatul va 
trebui să fie ajustat, căci a apărut condiția de depășire a domeniului de valori. 
Această condiţie se poate implementa ușor prin hardware, realizînd o funcţie SAU 
EXCLUSIV între: biții de transport către și de la bitul de semn : 


v=T, 9 T, 
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Concluzie : după operaţii aritmetice (ADD, ADC, SUB, SBC, INC, DEC) flagul P/V indică 
apariția unei depășiri de domeniu: i 

P/V = 1 a existat depășire; 

P/V = 0 nu a existat depășire. 
Dacă numerele cu care lucrăm sînt reprezentate cu semn şi dacă apare depăşire rezultatul 
trebuie corectat. 


Flagul P/V poate fi testat prin instrucțiuni de salt condiționat: JP PO, nn şi 
IP.PE, nn. 

JP PO, nn (jump if parity odd) se execută salt la adresa nn, dacă P/V=0; 

JP PE, nn (jump if parity even) se execută salt la adresa nn, dacă P/V=1. 
Remarcăm, că indiferent de faptul că P/V indică paritate sau depășire, mnemo- 
nica face referire mereu la paritate. Aceasta este o posibilă capcană pentru pro- 
gramatori, ei trebuind să știe ce anume indică flagul P/V în momentul în care 
se folosește una din instrucțiunile de salt condiționat ce testează starea acestui 
bit. 
Este momentul să facem o observaţie importantă. 
Acesta este punctul în câre mult amintita compatibilitate a microprocesorului Z80 cu pre- 
decesorul său 18080 șchioapătă un pic: dacă dorim ca toate programele scrise pentru micro- 
procesorul 18080 să funcţioneze ireproșabil şi pe Z80 atunci va trebui să verificăm toate 
instrucțiunile care testează flagul P/V — JP PO; JP PE; CALL PO; CALL PE; RET PO; 
RET PE. Ele vor cauza probabil salturi eronate pe Z80, dacă inițial (pe 18080) au fost folo- 
site pentru testarea parităţii după efectuarea unor instrucțiuni aritmetice. Pe Z80, P/V va 
indica în acest caz depășirea și nu paritatea. Spre norocul softiştilor experiența arată că 
aceste instrucțiuni de salt sînt mai rar folosite, și chiar în cazul utilizării lor majoritatea 
programatorilor le-au folosit după instrucțiuni logice. Oricum, atenţie | 


e Flagul N — este un indicator care memorează tipul ultimei operaţii arit- 
metice efectuate : adunare sau scădere. În registrul F el ocupă poziția bir 1. 
De ce se numește tocmai N, nu știm nici noi, referineţele bibliografice avute la 
dispoziție neindicînd nimic sugestiv în acest sens. 

N=1 dacă ultima operație aritmetică a fost adunare; 

N=0 dacă ultima operaţie aritmetică a fost scădere. 

Flagul N este folosit împreună cu indicatorul de transport intermediar H și cu 
indicatorul de transport Cy, peritru ajustarea numerelor zecimale codificate binar 
(BCD), de către instrucțiunea DAA. 

Utilizatorul nu dispune de instrucțiuni dedicate pentru testarea valorii acestui 
indicator. * 

e Flagul Cy (Carry — transport) — este indicatorul cel mai popular, afec- 
tat atît de operaţiile aritmetice/logice cît și de clasa operațiilor de rotire/depla- 
sare octet. El ocupă poziția cea mai puțin semnificativă (bit 0) în registrul indi- 
catorilor de condiţie F. 

Flagul Cy este înscris (valoarea 1), ori de cîte ori apare un transport de la cifra 
cea mai semnificativă în sus. Acesta este cazul, dacă pe urma unei adunări în arit- 
metica fără semn (gama de valori posibile 0—255) rezultă un număr mai mare de 
255. La scădere Cy = 1, dacă scăzătorul este mai mare decît descăzutul. 

Spre deosebire de toți ceilalți indicatori de condiție, în cazul flagului Cy există 
instrucțiuni dedicate pentru modificarea conținutului acestui bit: 

SCF (Set Carry Flag) cauzează Cy=1, iar 


CCF (Complement Carry Flag) complementează conţinutul Cy, Existenţa 
acestor instrucțiuni ne sugerează ideea să folosim indicatorul Cy ca indicator uni- 
versal de condiție. Un programator îşi poate fixa de exemplu regula ca Cy să fie 
3 Notat în Im. 0 prin C. 
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folosit ca indicator de eroare : gacă la întoarcerea dintr-o subrutină Cy=1, ieșirea 
„din subrutină să fie anormală. În acest caz programul apelant va abandona calea 
de prelucrare uzuală a rezultatelor subrutinei, și va trece la analiza și tratarea 
erorilor. Dacă Cy=0, ieșirea din subrutină să fie normală, programatorul putînd 
prelucra datele primite conform procedurii „interesante”. Dar acest exemplu 
este doar o idee, oricine putînd atașa alte semnificații posibile bitului Cy. 
Indicatorul Cy poate fi testat prin instrucțiuni de salt condiționat: JP NC, nn 
și JP C,nn. 
Folosind aceste instrucțiuni ramificația programului se va face după cum urmează : 
JP NC, nn (jump if non carry) — salt la nn, dacă Cy=0 
JP C,nn (jump if carry) — salt la nn, dacă Cy=1. 
Ca și în cazul celorlalte flaguri testabile prin instrucțiuni de salt condiționat și 
Cy poate dirija apeluri și reveniri condiționate din subrutine : 
CALL NC,nn; CALL C,nn; RET NC; RET C. 
Odată cu prezentarea indicatorului de transport Cy, am terminat prezentarea 
registrului F. Aţi remarcat poate o mică neconcordanţă : inițial am afirmat că 
registrul F are lungimea de 8 bit, iar pe parcurs n-am prezentat decît 6. 
Doi biți ai registrului F sînt lipsiți de semnificaţie, conținutul lor variind imprevizibil 
pe toată durata de funcționare a microprocesorului Z80  (notaţi cu X în Im. 0). 
Structura registrului F va fi deci: 
În Im. 0, VISIBLE—Z80 redă în mod ase- 
=: [sŢz [Puls] mănător structura registrului F. Remarcăm pre- 
il ze e ES ED : zența a două numere Pare de 8 biți în căsuţa 
Fig. 1.1, Structura registrului F afectată registrului F. Ca și în cazul acumulato- 
rului (A şi A”), există un registru F” numit registru 
de flaguri secundar. Dar și în acest caz doar unul, anume F, este activ. Conţinutul 
celor doi regiştri indicatori de stare poate fi interschimbat prin instrucțiunea EX 
AF, AF. Remarcăm faptul că toate operaţiile aritmetice/logice, care afectează indi- 
catorii de condiţie, precum și instrucţiunile care le folosesc, acționează totdeauna 
asupra valorilor cuprinse în registrul primar F. 


Registrul de reimprospătare a memoriilor dinamice R (Refresh) — este un 
registru cu lungimea de 7 bit, menit să asigure printr-o numărare ciclică de la 
0 la 127 (0000000—1111111) reîmprospătarea memoriilor RAM dinamice, din 
componența unui microcalculator, atunci cînd ele există. 

Pentru a-i înțelge mai bine menirea și modul în care se achită de sarcina-i încre- 
dințată, vom face din nou o paranteză. 

În memoriile RAM dinamice păstrarea informaţiei se face în celule a căror 
element de memorare este un condensator realizat în structura semiconducto- 
rului. Știind că un circuit de memorie dinamică avînd 65536 celule de memorie 
distincte este un circuit integrat cu 16 pini, a cărui structură (chip) nu depășește 
dimensiunea de 3 x 3 mm, ne putem da seama că și dimensiunile geometrice 
ale condensatoarelor de memorare și implicit capacitatea lor este foarte mică. 
Capacitatea unui condensator de memorare într-un circuit RAM dinamic nu depă- 
șește 10—15F, Datorită curenților de scurgere prin dielectricul acestor condensa- 
toare, ele au tendința de a se descărca, pierzînd astfel în timp treptat informaţia 
(1 sau 0) înregistrată în ele. Timpul limită în care această descărcare nu pericli- 
tează încă integritatea informaţiei stocate, este de aproximativ 2 ms. De aceea 
din 2 în 2 mis condensatoarele vor trebui repolarizate la valoarea lor inițială Această 
procedură se numește reîmprospătarea memoriei dinamice (refresh ). Care este 
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tehnica folosită ? Pentru a da un răspuns la această întrebare vom considera struc- 
tura circuitelor DRAM. 


La ora răspîndirii pe scară largă a microprocesoarelor de 8 bit cele mai răs- 
pîndite circuite DRAM au fost cele de 16 kbit. Ele au o organizare matricială 
avînd 128 linii și tot atîtea coloane. Astfel se acoperă întregul spațiu de adrese 
de 16 kbit : 128 x 128 = 16.384 = 16 kbit. Memoriile dinamice sînt astfel reali- 
Zate, încît selectarea unei celule pentru scriere sau citire reîmprospătează întregul 
rînd pe care se află elementul accedat. Ba chiar mai mult, nici nu trebuie făcut 
accesul pînă la celula dată ; este suficient să se selecteze rîndul respectiv. Reîmpros- 
pătarea memoriei dinamice se poate face în acest caz asigurînd ca toate cele 128 
de rînduri să fie selectate cel puţin o dată la 2 ms. Cele 128 de rînduri se pot 
codifica pe 7 linii (27=—=128) de adresă. .De aici rezultă că un registru numărător 
circular avînd lungimea de 7 bit ar putea sta la baza sistemului de reîmprospătare. 
(Același număr de biți — 7 — este suficient și în cazul utilizării unui circuit RAM 
dinamic avînd capacitatea de 64 kbit, căci aceste circuite conţin de fapt 4 grupe 
de 16 kbit). lată de ce registrul R are lungimea de 7 bit. Rămîne de văzut cum 
funcționează. Proiectanții microprocesorului Z80 au plecat de la ideea că în timpul 
decodificării unei instrucțiuni citite din memorie, microprocesorul nu efectuează 
nici o activitate externă. Magistrala de adrese a microprocesorului îşi poate 
schimba deci conținutul, pe biții ei inferiori AO — A6 apărînd conținutul regis- 
trului R, care acompaniat de 2 semnale de comandă (MREQ și RFSH) va putea 
asigura reîmprospătarea memoriei dinamice. 


După cum aţi realizat probabil, registrul R este înzestrat și cu un mecanism 
care îi incrementează automat conținutul la fiecare ciclu refresh. (Dacă micro- 
procesorul Z80 ar executa numai instrucțiuni cu un singur ciclu mașină, ex. NOP, 
conţinutul primilor 7 biți ai contorului 
program PC şi cei ai registrului R ar 


Ai ata! „5, A5 
varia sincron. Vizualizînd liniile de adrese | | | | 


pe un osciloscop, adresele A0 — A6 ar 

fi „curate“, pe cînd A7 — A15 aravea ag 

suprapuse peste porțiunea „,1' variația 9 PAR TA Mie A ni 
de frecvență egală cu cea a lui AO, da- 

torată desincronizării celor două numără- A? 1411 
toare (PC şi R), desincronizare care apare 

de la_A7 în sus, Fig. 1.2. Variația liniilor de adresă în cazul 


= Conţinutul registrului R poate fi execuției permanente a unei instrucțiuni cu 
înscris şi citit „via'"' acumulator : un singur ciclu maşină de 4 tacţi (ex. NOP) 


LD R,A — înscrie R 
LD A,R — citește R 


Acestea sînt singurele instrucțiuni prin care programatorul poate accede la regis- 
trul R. În rest el își trăieşte viața monotonă și autonomă de numărător circular 
de 7 bit. 

La inițializarea microprocesorului (aplicarea semnalului de comandă RESET), 
conținutul registrului de refresh R este încărcat cu O. 

Prezenţa registrului R este un cîștig semnificativ în favoarea microprocesorului 
Z80, ea scutindu-l pe proiectantul microcalculatorului de un efort considerabil, cel 
de a realiza o memorie cu 2 căi de acces (din partea procesorului și din partea 
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unui circuit de reîmprospătare extern ) și de a rezolva conflictele ce apar între cele 
două subansamble. 


Registrul vectorului de întreruperi | (Interrupt register) — este ultiriul în 
- șirul regiștrilor speciali ai microprocesorului Z80. El este un registru cu lungimea 
de 8 bit și servește în modul de întreruperi 2 (IM 2) la dirijarea (identificarea) 
sursei de cerere a întreruperilor. 


Prin întrerupere înțelegem fenomenul la apariția căruia microprocesorul abando- 
nează — la cererea unui eveniment extern — programul în curs de rulare, deserveşte 
— executind un program dedicat — evenimentul extern, după care se reîntoarce 
la programul abandonat, reluîndu-i execuţia din punctul în care ea fusese suspen- . 
dată. . 


Sînt multe aspecte care trebuiesc lămurite în legătură cu acest fenomen. Asu- 
pra lor vom reveni într-una din aventurile realizate cu ajutorul lui VISIBLE—Z80. 
Ne oprim acum doar asupra unui aspect : cum identifică microprocesorul perifericul 
(sau evenimentul extern) care a solicitat întreruperea ? Cererea de întrerupere 
INT sosește fizic la microprocesor pe linia-de stare avînd același nume. Pentru 
identificarea apelantului, și implicit pentru localizarea rutinei de tratare aferente 
s-au elaborat numeroase. soluţii, și se pot imagina cel puțin atîtea noi variante. 
Soluția cea mai rapidă și cea mai flexibilă pare a fi identificarea vectorizată : din 
diverse surse se constituie o adresă de memorie, care este însăși adresa de început 
a rutinei de tratare a cererii de întrerupere recepționate. Această adresă se încarcă 
în contorul program PC și microprocesorul a și ajuns la rutina dorită. Care sînt 
aceste surse ? În cazul microprocesorului Z80, perifericul care solicită întrerupe- 
rea va plasa, o dată cu acceptarea cererii ei, pe liniile de date un octet de adresă, 
pentru identificare. Fiecare periferic are adresa lui proprie, inconfundabilă cu 
altele. Asta ar fi prima sursă. Cea de a doua sursă este însăși registrul |. Conţi- 
nutul lui se plasează pe liniile de adresă superioare A8—A15. Din cei 2 octeți 
atașați se formează o adresă de memorie A0—A15 (vector de întrerupere) de 
la care se citesc 2 octeți succesivi din memorie, și se încarcă în PC efectuîndu-se 
saltul la rutina căutată. S-a identificat astfel implicit, fără căutări sau testări, 
sursa cererii: de întrerupere. Iniţializarea registrului |, precum și asigurarea fap- 
tului ca în memorie, la adresa vectorului de întrerupere, să se afle adresa de 
început a rutinei de tratare a întreruperii respective, cade bineînțeles în sarcina 
programatorului. Procedura de.adresare folosită este dublu indirectă. A doua treaptă 
de adresare — cea de citire a adresei efective de început a subrutinei de tratare 
a întreruperii acceptate,— este indirectă, prin memorie. Începătorii vor putea 
găsi detalii privind tehnicile de admasas> în paragraful : „Tehnici de adresare”. 
Programatorul accede registrul |, <a şi registrul R, „„via'”' acumulator: 


LD |I,A — înscrie o valoare în; 
LD A,l — citește valoarea lui |. 


Acestea sînt singurele instrucțiuni prin care programatorul poate comunica cu 
registrul |. 


La inițializarea microprocesorului (aplicarea semnalului de comandă RESET), în 
registrul | se înscrie valoarea 0. * 


Continuînd explorarea fotografiei Im 0., să trecem la regiștri de uz general 
ai microprocesorului Z80. 
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Regiștrii de uz general au menirea, așa cum am văzut, să păstreze în imediata 
apropiere a „,focarului'' microprocesorului (circuit de comandă, ALU) date, care 
să poată fi accedate rapid, evitîndu-se pe cît se poate accesele la memorie, ope- 
rații care sînt mult mai lente și reduc astfel viteza de lucru a microprocesorului. 


Într-o grupare semnificativă a figurii din Im. O distingem alături de regiştri 
deja prezentați (PC, SP, R, |) alte căsuțe simbolizate cu B, C, D,E,H,L, regiș- 
tri de uz general primari, B*, C',, D', E”, H', L”, regiștri de uz general seundari, 
precum și IX respectiv IY care sînt regiștri de index. 


Regiștrii B și C : sînt regiștri generali de 8 bit. Există o multitudine de ins- 
trucțiuni (de transfer, aritmetice, logice, de rotire, etc.) care tratează „conținutul 
acestor regiștri. Ei nu au fost figurați întîmplător pe aceeași linie: în anumite 
condiţii ei se pot atașa, formînd un registru pereche BC, avînd lungimea de 16 bit. 
În această situație B este octetul cel mai semnificativ, iar C octetul cel mai puțin 
semnificativ. Există bineînțeles instrucțiuni care tratează perechea BC ca un 
registru de 16 bit (instrucțiuni de transfer, instrucțiuni aritmetice). 


Regiștrii D şi E: se caracterizează prin aceleași trăsături ca și regiștri B și 
C. Atunci cînd perechea DE formează un registru dublu de 16 bit, D ocupă 
octetul superior iar E octetul inferior. 


Regiștrii H şi L : diferă de cei anteriori B, C, D, E doar prin faptul că sînt 
implicați într-un număr mai mare de instrucțiuni, avînd astfel un grad de funcţio- 
nalitate sporit faţă de BC și respectiv DE. Atunci cînd ei formează o pereche HL, 
registrul H ocupă. octetul superior, iar L cel inferior. Pentru ca cititorul să poată 
sesiza de pe acuma plusul de funcționalitate menționat, prezentăm cîteva elemente 
legate de funcționarea microprocesorului, în avans. Știm că operaţiile aritmetice 
și logice lucrează cu doi operanzi. Unul din aceștia va fi obligatoriu locat în regis- 
trul acumulator A. Celălalt se află de obicei într-unul din regiștri de uz general 
B, C, D,E,H,L. Există însăși posibilitatea de a loca cel de al doilea operand 
în memorie, la o adresă oarecare. Pentru a efectua o operaţie aritmetică sau logică 
între registrul A și conţinutul celulei de memorie respective, adresa celulei se va 
înscrie în' registrul dublu HL. Perechea HL devine astfel principalul instrument de 
adresare indirectă a unor operanzi locaţi în memorie la adrese cunoscute. Nu există 
în schimb operaţii aritmetice/logice care să folosească pentru adresarea operan- 
dului locat în memorie conținutul regiștrilor dubli BC și DE. Se pot folosi în 
schimb regiștrii IX și IY. 


Regiștrii index |X și IY : sînt prin definiția dată de producători, regiștri de 
16 bit. Ei sînt dedicați eminamente pentru stocarea unor adrese de memorie. Faptul 
că există instrucțiuni care tratează acești regiștri ca și regiștri de 8 bit, este 
ascuns sub voalul tăcerii de către fabricanți. ş vom trata deci ca regiștri de 16 
bit. (Pentru informarea cititorului vom prezenta și trăsăturile tainice ale acestor 
regiștri în cap. G (COMPLEMENTE). Regiștri IX și IY au fost gîndiţi să fie uti- 
lizați atunci cînd trebuiesc efectuate operaţii aritmetice[logice asupra unor cîmpuri 
de date, date ce sînt așezate la adrese succesive de memorie, formînd astfel un 
tabel. Regiștrii index nu vor conţine adresa celulei care se dorește a fitratată. 
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Ei conţin adresa de. început a tabelei de date. Data dorită se va localiza adăugînd 
la adresa de început a tabelei (adresa de bază), indicele (numărul de ordine) datei 
respective. Indicele datei dorite se specifică explicit în enunţul instrucţiunii, valoa- 
rea lui fiind adunată în cursul execuției instrucţiunii la adresa de bază, conținută 
în registrul index IX sau IY, formîndu-se astfel adresa efectivă a celulei de memo- 
rie dorite. Spre exemplificare să considerăm instrucțiunea : 


ADD A,(IX + 5) 


ea adună conținutul registrului A cu cel al celui de-al cincilea element din tabelul 
de date, care începe la adresa conținută în registrul IX. Conţinutul registrului 
IX nu se modifică pe parcursul execuției acestei instrucțiuni. Datele din tabelele 
adresate cu registrul index vor fi date cu lungimea de 1 octet. Numărul maxim 
de elemente ce pot fi reperate cu o adresă de bază este de 256, datorită faptului 
că indicele care apare în cîmpul instrucţiunii are lungimea de 1 octet. Programa- 
torul dispune bineînțeles de instrucțiuni de inițializare, salvare și restaurare a 
regiștrilor index IX și IY. Ba chiar mai mult, ei pot fi folosiţi și pentru efectua- 
rea unor operaţii aritmetice de 16 bit, înlesnindu-se astfel calculul unor adrese 
de bază, prin program. Această facilitate suplimentară îi îndeamnă pe mulți pro- 
gramatori, să folosească regiștri dubli IX și IY în alt scop decît cel pentru care ei 
au fost gîndiți, ceea ce desigur nu este de condamnat. Astfel regiștri IX şi IY 
sînt des utilizați ca elemente de memorare a unor valori numerice de 16 bit. 
Amintim că tehnica de adresare a unor operanzi locați în memorie, folosind regiş- 
tri IX și IY se numește adresare indexată. Vom detalia această tehnică în paragra- 
ful „Tehnici de adresare”. 


Regiştri secundari B”, C', D', E", H',L". 
Ca și în cazul regiștrilor speciali A și F, unde am întîlnit deja regiștri secundari 
A” respectiv F”, și regiștri de uz general au cîte o dublură: regiștri secundari 
BUC DEL: 
Conţinutul regiștrilor primari și a celor secundari poate fi interschimbat concomi- 
tent, printr-o singură instrucțiune : 


EXX 


Toate instrucţiunile care implică regiştri de uz generalB, C, D,E,H,L acţionează 
asupra conținutului regiştrilor primari. Pentru a putea opera cu conținutul regiştri- 
lor secundari, el trebuie transferat în regiștri primari, folosind instrucțiunea 
EXX. 


În interiorul oricărui microprocesor există și anumiţi regiștri care nu sînt folo- 
siţi în mod explicit de către instrucțiunile acelui microprocesor. În fotografia din 
Im. O am notat acești regiștri cu T, T,W şi Z. Ei sînt regiștri de manevră, trans- 
parenţi utilizatorului. 


Regiştri W şi Z: sînt regiştri de cîte 8 bit care pot fi tratați și ca regiș- 
tri dubli de 16 bit. 
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Exemplificăm necesitatea existenței acestor regiștri analizînd o instrucțiune 
simplă a microprocesorului Z80. 


JP. 1234H 


Aceasta este o instrucțiune de salt necondiţionat (jump). După efectuarea ei 
microprocesorul va executa secvența de cod (programul) care începe la adresa 
hexazecimală 1234. Instrucţiunea se codifică pe 3 octeți : 


C3H 34H 12H 


Cei trei octeți ocupă în memorie locații succesive în ordinea enunțată. C3H repre- 
zintă codul instrucţiunii de salt necondiţionat (jump); 34H reprezintă octetul 
inferior (mai puțin semnificativ) al adresei de salt ; 12H reprezintă  octetul superior 
(cel mai semnificativ) al adresei de salt. Pentru a fi mai expliciți să specificăm o 
adresă oarecare la care este locată instrucțiunea : fie această adresă 100H: 


0100H — C3H 
0101H — 34H 
0102H — 12H 


În momentul în care începe execuția instrucţiunii, contorul program PC 
conține valoarea 0100H. După citirea codului instrucţiunii, C3H, PC este incre- 
mentat, conținutul lui devenind 0101H. De la această adresă se citește octetul 
inferior (34H) al adresei de salt. PC se incrementează din nou, indicînd 0102H. 


Ei, acu-i acu ! Unde se depune acest octet? Dacă el s-ar depune în octetul 
inferior al contorului program PC, atunci conținutul acestuia ar deveni: 0134H, 
şi ar fi deci imposibilă citirea octetului superior al adresei de salt, octet care se 
află în memorie la adresa 0102H. De aceea este necesar ca în interiorul micro- 
procesorului să existe un registru tampon. Fie acest registru registrul Z. Aici 
se depune octetul inferior al adresei de salt. În următorul ciclu de funcționare 
microprocesorul citește de la adresa 0102H octetul superior al adresei de salt 
12H, și îl depune în registrul tampon W. Odată efectuate: aceste manevre con- 
ținutul registrului WZ se transferă în PC, efecutîndu-se saltul dorit, la adresa 
1234H. | 


Regiștri temporari T: sînt regiștri de intrare în unitatea aritmetică/logică 
(ALU). În Im 0. acești regiștri au același nume T, datorită faptului că n-am 
dorit să încărcăm utilizatorul programului VISIBLE—Z80 cu elemente care sînt 
totuși secundare ca importanță. Dorind să sugerăm cititorului o atitudine critică, 
care să-l determine a căuta cauzele oricărui fenomen, vom argumenta și pentru 
necesitatea existenței a doi regiștri tampon la intrarea în ALU. În literatura de 
firmă, schema bloc a microprocesorului apare cu un singur registru tampon la 
intrarea ALU, cealaltă intrare fiind legată la acumulatorul A. La prima vedere 
această afirmaţie pare a fi corectă, noi știind deja că toate operaţiile ALU folosesc 
unul din operanzi provenind din A. Intercalarea unui registru tampon între A și 
ALU pare a fi inutilă. Dar analiza detailată a instrucţiunilor microprocesorului, 
demonstrează contrariul. 

Să considerăm exemplul deja prezentat : 


ADD  A,(1X+5) 
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Fie conținutul registrului IX o valoare oarecare (număr hexazecimal! cu patru cifre 
semnificative = 16 bit), de exemplu 44FEH. Înainte de a se efectua adunarea 
stipulată în instrucțiune, trebuie citit operandul 2 din memorie, de la adresa 
1X4+5 = 44FEH+45. Suma dintre adresa de bază 44FEH și indicele cerut 5 va fi 
efectuată de către microprocesor tot prin ALU. Această etapă nu are însă voie 
să afecteze conținutul registrului A, fiindcă astfel am compromite din start obiec- 
tivul final al instrucţiunii : anume, să calculeze suma dintre acumulator și celula 
de memorie avînd adresa 44FEH + 5 = 4502H. 
lată deci o operaţie aritmetică intermediară, cea de calcul a adresei elementului 
indexat, care se face, fără participarea acumulatorului A. Registrul tampon din 
partea stingă va conţine de exemplu indicele 5 și cel din dreapta octetul inferior 
al adresei de bază: FEH. 

Astfel s-a demonstrat necesitatea prezenţei unui registru tampon între A 
și ALU. | 

De ce nu se poate efectua adunarea a doi regiștri 


ADD A,B 


fără existența registrului tampon T din dreapta, este o întrebare la care răspun- 
sul ar trebui să intre în detalii hardware care depășesc obiectivul acestei cărți. 


Registrul tampon de date DB (Data Buffer) este un registru bidirecțional 
de 8 bit, care delimitează interiorul microprocesorului, de lumea externă. El 
este necesar în primul rînd pentru a menţine datele ce sînt trimise din celulele 
registrilor interni spre memorie, sau spre periferice. 


Registrul tampon de adrese AB (Address Buffer) izolează pe de o parte 
magistrala externă de adrese de cea internă. În afară de aceasta el are un rol de 
memorare temporară a unor adrese, rol pe care l-am explicitat la relevarea mode- 
lului funcțional al unui microprocesor ipotetic. 


Sperînd că nu v-am epuizat total cu această prezentare, închidem aici lista 
regiștrilor interni ai microprocesorului Z80. 


Acest bloc funcțional, notat în Im. O cu Command Circuit, este inima şi 
creierul oricărei unităţi centrale de calculator și implicit al microprocesoarelor. 
Sarcina lui este să guverneze toate activitățile microprocesorului, începînd din 
momentul în care acestuia i se aplică tensiune și semnal de tact. 


Circuitul de comandă generează toate semnalele de comandă pentru activarea 
secvențială a tuturor elementelor interne și a „,lumii"” externe, din microcalculator. 
În linii mari, în activitatea lui se disting următoarele faze majore : citește din 
memorie codul instrucţiunii de executat, îl decodifică. Inţelegînd semnificația 
codului citit programează toate activitățile interne și externe pentru a duce Ja 
bun sfîrșit comanda primită. Dacă aceste activități sînt multe sau puține, o lăsăm 
pe seama cititorului. Amintim doar că cea mai scurtă instrucțiune se execută în 
4 tacți procesor (ex. : transferul între regiştri : LD A, B, LD D, E, etc.), pe cînd 
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cea mai lungă necesită 23 de stări de tact distincte, fiecare cu semnificaţia ei 
(ex. : ștergerea unui bit dintr-o locație de memorie adresată printr-un registru 
index : RES 3, (IX + IND)). 

În blocul funcțional al circuitului de comandă am inclus și bistabilii de vali- 
dare|inhibare a sistemului de întreruperi IFFA şi IFF2, precum şi registrul de2 
bit al modulului de întreruperi folosit. Dacă IFF1 șiIFF2 au valoarea 1,atunci 
sistemul de întreruperi este validat, microprocesorul acceptînd cererile de întrerupere 
sosite din lumea externă. Dacă ele au valoarea zero, sistemul de întreruperi este 
inhibat, cererile de întrerupere fiind neglijate. În registrul MOD se stochează 
modul de întrerupere selectat prin una din instrucțiunile de comandă IMO, 
IM 1, IM 2. Asupra rolului acestor elemente funcționale și a funcționării lor vom 
reveni în aventurile pe care le vom întreprinde cu VISIBLE—Z80. 


Proiectarea și analizarea unui astfel de circuit electronic este de neconceput 
fără folosirea intensivă a unor tehnici de proiectare asistată de calculator și fără 
tehnologie de virf. Nu vom insista asupra detaliilor constructive și de funcţio- 
nare a circuitului de comandă pentru a nu devia de la obiectul cărții. Amintim 
doar că orice relatare pe care am face-o referitor la acest aspect, ar fi pur teore- 
tică, firmele producătoare nepublicînd mai nimic despre această structură func- 
țională a microprocesorului. 


Așa cum rezultă din relatările anterioare, ALU este un bloc funcțional al micro- 
procesoarelor, destinat să efectueze operațiile aritmetice și logice. Unitatea arit- 
metică/logică. a microprocesorului Z80 este de tip paralel, avînd lățimea de 8 
bit. Această unitate centrală poate executa două operaţii aritmetice : adunarea și 
scăderea a două numere binare de cîte 8 bit. Operaţiile logice acționează de aseme- 
nea pe cuvinte de cîte 8 bit. Ele sînt ȘI, SAU, SAU EXCLUSIV, COMPARAŢIE 
şi COMPLEMENTARE (față de 1 și 2). 

Unul din operanzii implicați în operaţiile ALU, va proveni totdeauna din regis- 
trul acumulator A. Odată cu generarea rezultatului operaţiilor aritmetice/logice, 
se poziţionează și indicatorii de condiție ai registrului F. 

Setul de instrucțiuni aritmetice și logice pare a fi sărac pentru cel care doreşte să 
execute calcule științifice folosind instrucțiunile enunțate. Pentru începători pare 
puțin probabil să calculezi logaritmul unui număr real cu o precizie de 16 cifre 
semnificative, atunci cînd dispui de o unitate aritmetică care știe doar să adune 
și să scadă două numere întregi avînd valori cuprinse în limitele [0,255]. Ţinem 
să-i liniștim afirmînd că este posibil, trebuie să cunoşti însă bazele analizei nume- 
rice pentru a reduce calculul unui logaritm la adunări și scăderi, și să ai iscusința 
de a transpune acești algoritmi în programe scrise cu ajutorul instrucțiunilor 
limitate ale microprocesoarelor. 

ALU efectuează scăderile transformînd scăderile în adunări. Numerele de scăzut 
(negative) sînt transformate în complementul lor față de 2. 

Circuitele electronice care realizează funcţiile ALU sînt de tip combinaţional, 
fiind mult mai simple decît cele din circuitul de comandă a microprocesorului. 
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1.4. Magistralele interne 


Magistrala de 8 bit. 


Știind că lățimea majorității regiștrilor din interiorul microprocesorului Z80 
este 'de un octet, deducem că în interiorul lui trebuie să existe o magistrală 
avînd lățimea de 8 bit pentru a se putea efectua transferurile interne. La această 
magistrală de date care începe la bufferul de date DB se leagă registrul instruc- 
țiune IR, acumulatorul A, regiștri tampon T de la intrarea ALU, ieșirea ALU, 
precum și toți ceilalți regiștri interni de 8 bit. 


Magistrala de 16 bit. 


Adresele de memorie pe care microprocesorul le generează au lățimea de 
16 bit. În interiorul microprocesorului ele se vehiculează pe o magistrală locală 
care se termină la registrul tampon pentru adrese AB (Address Buffer). 

- Din studiul detailat al funcționării microprocesorului rezultă că toți regiștri 
B, C, D,E,H,L, IX, IY, SP, PC și WZ au cîte 2 ieşiri: una din ieșiri este racor- 
dată la magistrala de 8 bit, folosindu-se pentru transferul de date ; cealaltă ieșire 
a lor este legată la octetul superior sau inferior al magistralei de 16 bit, permițînd 
astfel generarea unor adrese de 16 bit pentru adresarea memoriei externe. 


Semnalele de comandă interne 


Pentru a putea activa în ordinea dorită, fiecare element funcțional intern, 
circuitul de comandă al microprocesorului dispune de o multitudine de semnale 
de comandă, semnale care ajung la toate părțile lui componente. Ele nu au fost 
reprezentate în modelul din Im -0, numărullor mare nepermițind acest lucru. 
Oricum este suficient să știm de existenţa lor. Nefiind nominalizate, aceste sem- 
nale vor fi grupate sub numele generic de semnale de comandă interne, 
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SEMNALELE EXTERNE 


După ce am cunoscut structura internă a microprocesorului, este momentul 
să prezentăm semnalele prin care el comunică cu lumea externă. În fig. 2.1. 
redăm semnalele externe ale microprocesorului Z80, grupate funcțional. 


Distingem 3 clase mari de semnale : magistrala de date, magistrala de adrese 
și magistrala de comenzi. 


Semnale de i] 
comanda ORA 


WR 2 Z 80 


UB 8800 : $ Magistrala de 
1 HALT : MK3880 i adrese 
ae 78400 9 
Semnale de WAIT MMN 80 
stare 
4 


Acces 
magistrale 


"RESEf 
BUSRA 
"BUSAK 


Magistrala de 
date 


Fig. 2.1. Semnalele externe ale microprocesorului Z80 
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Cele 8 linii care pornesc din registrul tampon de date DB al microprocesoru- 
lui sînt folosite pentru a asigura transferul de date între microprocesor, memorie 
şi dispozitivele de intrare/ieșire. Împreună, ele formează magistrala de date a 
microprocesorului, notată cu DO-— D7. Magistrala de date a microprocesorului 
este bidirecțională. Pe ea intră date atunci cînd se efectuează o citire din memorie 
sau dispozitivele de intrare/ieșire, și ies date la efectuarea unei scrieri. 

Magistrala este de tip tri-state: pe lîngă cele două nivele logice active (0 
și 1), fiecare linie de date poate avea o stare inhibată, de înaltă impedanță. Această 
stare este utilă dacă în anumite momente de funcționare, magistrala de date 
trebuie cedată de către microprocesor unei alte componente din microcalculator. 
Un exemplu în acest sens îl poate constitui efectuarea unuitransfer de date, 
direct de la un dispozitiv de intrare/ieșire în memorie (sau invers) procedeu numit 

" DMA (Direct Memory Acces — acces direct la memorie). 

Magistrala de date este neinversată : biții de valoare 1 vor apare cu nivele de 
tensiune ridicată (3 — 4 V), pe cînd cei de valoare O vor fi materializați prin nivele 
de tensiune scăzute (0,1 — 0,8 V). DO este bitul cel mai puțin semnificativ -al 
octeților ce circulă pe magistrala de date. 


Cele 16 linii ce-și au originea în registrul tampon de adrese AB a micro- 
procesorului, formează împreună magistrala de adrese. Ea este unidirecțională: 
adresele ies din microprocesor pentru a fi transmise la circuitele de memorie și 
cele de intrare/ieșire ale microcalculatorului. 

Cele 16 linii de adresă permit adresarea directă a 64 k de“memorie RAM. 
Pentru- adresarea dispozitivelor de intrare/ieșire se decodifică de obicei octetul 
inferior al registrului de adrese A0-— A7, putîpdu-se astfel lega 256x2 dispozi- 
tive de intrare/ieșire în sistem. Dacă transferul de date între procesor și dispozi- 
tivele de intrare/ieșire se realizează cu ajutorul instrucțiunilor ce folosesc adresa- 
-rea indirectă IN A,(C) respectiv OUT (C), A atunci în ciclurile de intrare/ 
ieșire pe magistrala de adrese va apare conținutul regiștrilor B (A15 — A8) și 
C (A7 — A0). Decodificînd ambii octeți ai magistralei de adrese, numărul dispo- 
zitivelor de intrare/ieșire adresabile direct de către microprocesor crește la 
65536 x2. 

În ciclul de reîmprospătare a memoriei, liniile de adresă A0— A6 conțin 
adresa rîndului refreșat (conţinutul registrului R). 

Aidoma magistralei de date și magistrala de adrese poate avea 3 stări electrice 
(logice) distincte : 2 stări active (1 sau 0) și o stare inhibată, de înaltă impedanţă. 
Menirea celei de a treia stări este identică cu cea enunțată la magistrala de date: 

Linia A0 conţine bitul cel mai buţin semnificativ al adreselor. 
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Acest nume este un nume generic, căci spre deosebire de celelalte două 
magistrale, în care liniile fiecăreia aveau semnificații similare, magistrala de comenzi 
este reuniunea unor semnale individuale de intrare sau de ieșire din microprocesor, 
avind fiecare un rol aparte. 

Le clasificăm totuși în trei grupe: 

— semnalul de tact 

— semnale de comandă 

— semnale de stare 


Este un semnal TTL, constituind elementul motor al microprocesorului. Toate 
evenimentele interne ale microprocesorului apar sincronizate cu acest semnal. 
Frecvența semnalului poate varia în limite destul de largi, interesul nostru fiind 
însă acela de a lucra cu frecvențe cît mai mari ale semnalului de ceas, datorită 
faptului că viteza de execuție a instrucțiunilor este direct proporţională cu frecvenţa 
tactului Q. 

Primele microprocesoare Z80 au avut ca limită superioară a frecvenţei de tact 
2,5 MHz. Ulterior au apărut variante mai rapide: Z8O0A cu 4 MHz și Z80B cu 
6 MHz. 

Fiecare instrucțiune executată de microprocesor durează un număr întreg de 
tacţi. La descrierea setului de instrucțiuni, vom specifica durata fiecărei instruc- 
ţiuni, exprimată în numărul de tacți procesor necesari pentru execuţia ei. 


În această categorie includem semnalele care sînt generate de către micro- 
procesor. Cu ajutorul lor, circuitul de comandă al microprocesorului dirijează 
activităţile din interiorul microcalculatorului. 


M1 — (Machine cycle 1 — ciclul mașină 1) este un semnal activ în starea 0. 
El apare ori de cîte ori microprocesorul citește din memorie codul unei. instruc- 
ţiuni, operație numită fetch. În această situație el este însoţit și de alte două 
semnale MREQ (Memory REQuest) și RD (ReaD) care concură la citirea codului 
din memorie. MT se activează și în ciclul de acceptare a unei cereri de întrerupere . 


În acest caz el se activează împreună cu IORQ (Input/Output ReQuest), Apariția 
lor concomitentă determină perifericul apelant să depună pe magistrala de date 
octetul inferior al vectorului de întrerupere. 


Există instrucțiuni care sînt descrise prin două sau trei coduri de operaţie. În 
cursul execuţiei acestora M1 se va activa la citirea fiecărui octet cod de operaţie. 
M1 poate trece în starea de înaltă impedanță (tri-state). 
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MREQ — (Memory REQuest — cerere de acces la memorie ), este un semnal 
activ în starea 0. El se activează ori de cîte ori microprocesorul dorește să efec- 
tueze un acces la memorie, fie pentru citirea, fie pentru înscrierea ei. 


MREQ se activează și pe parcursul ciclului de reîmprospătare a memoriilor dinamice, 
acompaniat de semnalul RFSH. 


În momentul apariției acestui semnal magistrala de adrese conţine pe liniile 
AO — A15 adresa celulei de memorie la care se va efectua accesul. 


MREQ pcate trece în starea de înaltă impedanță (tri-state ). 


RD -- (ReaD — citește) este un semnal activ în starea 0. El este activat 
atunci cînd microprocesorul execută citirea unui octet, din memorie sau de la un 
dispozitiv de intrare. Elementul apelat (celula de memorie sau dispozitivul de 
intrare) va transfera la apariția acestui semnal conţinutul lui pe magistrala de date. 


Sursa datei de citit se stabilește din starea semnalelor MREQ și IORQ. 
RD poate trece în starea de înaltă impedanță (tri-state). 


WR — (WRite — scrie) este un semnal activ în starea 0. El se activează 
atunci cînd microprocesorul urmează să scrie un octet în memorie sau într-un 
dispozitiv de ieșire. Destinația octetului transferat se stabilește din starea semnale- 


lor MREQ și IORQ. Înainte de activarea semnalului WR microprocesorul va depu- 
ne pe magistrala de date octetul de transferat. Datele fiind stabile în momentul 


apariției semnalului de scriere WR, el poate fi folosit (frontul său căzător) pen- 
tru înscrierea lor în celule de memorie sau dispozitivul de ieșire dorit. 


WR poate trece în starea de înaltă impedanță (tri-state). 


IORQ — (Input/Output ReQuest — cerere de acces la dispozitivul de intra- 
re/ieșire) est este un semnal activ în starea 0. El este acompaniat de unul din semnalele 


RD sau WR, împreună cu care determină tipul de acces efectuat la dispozitivele 
de intrare/ieșire. În ciclul de acceptare a cererii de întrerupere, IORQ se activează 
împreună cu M1. Prezența celor două semnale semnifică acceptarea unei cereri de 
întrerupere. IORQ poate trece în starea de înaltă impedanţă (tri-state). 


RFSH — (ReFreSH — reîmprospătare) este un semnal activ în starea 0. 
El se generează în ciclul de reîmprospătare a memoriilor dinamice. Prezenţa acestui 
semnal, activat, înseamnă că pe liniile A0-— A6 s-a depus conținutul registrului 


R. La apariția semnalului RFSH aceste linii nefiind încă stabilizate, se recomandă 


să se folosească semnalul MREQ, care apare în acest ciclu puțin mai tîrziu, pen- 
tru declanşarea accesului de reîmprospătare a memoriei. 


HALT — (Halt — oprește ) este un semnal activ în starea 0, prin care micro- 
procesorul aduce la cunoștința sistemului, faptul că a executat o instrucțiune 


HALT și este oprit. Din această stare, microprocesorul nu poate fi scos decît 
printr-o întrerupere INT (dacă IFF1 = 1), o întrerupere nemascabilă NMI, sau o 


reinițializare RESET. În realitate microprocesorul nu stă pe loc, ci execută în 
continuare instrucțiuni NOP (No OPeration) pentru a asigura reîmprospătarea 
unei eventuale memorii dinamice din sistem. 
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Dacă ieșirea din starea HALT s-a făcut printr-o întrerupere, (mascabilă sau nemas- 
cabilă), după tratarea ei, execuția programului va continua de la instrucțiunea locată 
la adresa următoare instrucţiunii HALT. 


BUSAK (BUS AcKnowledge — acceptarea cererii de magistrală) este un 
semnal activ în starea 0, prin care microprocesorul confirmă acceptarea unei cereri 
BUSRQ, de cedare a magistralelor. Semnalul BUSAK apare totdeauna după ter- 
minarea unui ciclu mașină, după ce microprocesorul și-a pus în stare de înaltă 
impedanță magistralele (date, adrese, comenzi). 

BUSAK nu trece niciodată în starea de înaltă impedanţă. 


2.3.3. Semnale de stare 


O fi microprocesorul „creierul și conducătorul” vieţii interne a unui micro- 
calculator, dar oricît de atotputernic ar fi, nu-și poate permite să dea comenzi 
orbește, fără să-i pese de răspunsul celorlalte componente din sistem. Uneori va 
trebui să-și încetinească ritmul, alteori va fi întrerupt în marșul său, părăsind tem- 
porar drumul pe care se afla, pentru a se putea îngriji la cerere de subalternii 
săi, ba chiar mai mult, în anumite circumstanțe va trebui să stea deoparte, lăsîn- 
du-i și pe alții să vorbească — să preia comanda — dacă există activități pe care 
ei le pot efectua mai rapid și mai eficient. 

În ultimă instanță, dacă în munca sa microprocesorul s-a pierdut pe drum, 
pe cărările accidentate ale unui program insuficient de bine pus la punct, tre- 
buie să existe posibilitatea de a-l readuce cu „picioarele pe retprn forțindu- -] 
să ia totul de la început. 

Microprocesorul culege informaţiile necesare pentru luarea unor astfel de 
decizii, prin intermediul unor semnale de intrare numite de către noi, semnale 
de stare. 


Să le cunoaștem: 


WAIT — (Așteaptă ) este un „strigăt'' emis de elementul apelat (celulă de 
memorie sau dispozitiv de intrare/ieșire) prin care acesta semnalizează micro- 
procesorului faptul că merge prea repede, și el, colaboratorul, nu poate ține pasul. 
In fiecare ciclu de memorie sau de e intrare/ieșire, după lansarea comenzii (activarea 
semnalelor MREQ sau 1ORQ şi RD sau WR), circuitul de comandă al micropro- 


cesorului analizează starea liniei WAIT. Dacă ea este activă (valoare 0) atunci se 
inserează cicluri de tact suplimentare de așteptare, pînă cînd elementul apelat își 
termină treaba. La dispariția semnalului WAIT, microprocesorul continuă exe- 
cuția instrucţiunii ca și cum nu s-ar fi întîmplat nimic. Acest semnal permite ca 
şi un microprocesor ori cît de rapid să poată coexista și colabora cu circuite de 
memorie sau de intrare/ieșire lente. Dacă în sistem coexistă elemente rapide 
(ex. : circuite RAM cu timp de acces de 100-200 ns.) și lente (ex.: memorie 
de ferită cu timp de acces de ordinul microsecundelor), semnalul WAIT adaptea- 
ză viteza de rulare a microprocesorului la posibilităţile -concrete ale fiecăruia. 
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Specificăm totuși, că dacă în sistem există memorii RAM dinamice care așteaptă 
să fie reîmprospătate de către microprocesor, atunci așteptarea cauzată de semnalul 
WAIT nu poate fi oricît de lungă, fiindcă altfel s-ar risca pierderea informaţiei 
stocate în DRAM. : 


INT (INTerrupt — întrerupere) este „petiția”' depusă de un element din 
sistem (de obicei un dispozitiv de intrare/ieșire), prin care se solicită participarea 
microprocesorului la rezolvarea unei situații noi, create de apariția unui eveniment 
extern. Dacă sistemul de întreruperi al microprocesorului este validat, atunci acti- 
varea semnalului INT (valoare 0), va declansa abandonarea -programului în curs 
de execuţie și microprocesorul efectuează un salt la o rutină în care tratează 
cererea de întrerupere. După terminarea rutinei de întrerupere microprocesorul 
se întoarce în programul abandonat, reluîndu-i execuția din punctul în care a fost 
abandonat. Cererea de întrerupere este acceptată numai după terminarea ultimu- 
lui ciclu mașină a instrucţiunii în curs de execuţie. Cererea de întrerupere este 
ignorată dacă microprocesorul este în stare de așteptare (WAIT), dacă este sus- 
pendat (BUSAK), sau dacă sistemul de întreruperi este inhibat (bistabilul IFF1=0). 
Dacă cererea de întrerupere se acceptă (apar concomitent semnalele M1 și 
IORQ), saltul la începutul rutinei de tratare a întreruperii se va efectua în diverse 
moduri în funcție de regimul programat IM 0, IM 1 sau IM 2 (Interrupt Mode). 


NMI — (Non Mascable Interrupt — întrerupere nemascabilă ) este „pumnul 
în masă” bătut de un element din sistem la apariția unui fenomen care trebuie 
deservit imediat, indiferent de importanța programului în curs de execuţie. Pe 
cînd cererile de întrerupere sosite. pe linia INT puteau fi desconsiderate — prin 
inhibarea pe cale software a sistemului de întreruperi, cererile sosite pe linia 
NMI vor fi obligatoriu deservite, în cel mai scurt timp posibil (la terminarea ins- 
trucțiunii în curs de execuţie). 

Există și două cazuri în care cererea NM rămîne fără răspuns : în situaţiile în care 
microprocesorul -este imobilizat (stare WAIT continuă, sau BUSAK). 


NMI va întrerupe chiar și un program de tratare a unei întreruperi sosite 
pe linia INT. | 

La acceptarea cererii de întrerupere nemascabilă, microprocesorul salvează 
conținutul contorului program PC pe stivă și execută un salt necondiţionat la 


adresa 0066H, unde trebuie să înceapă rutina de tratare a întreruperilor nemasca- 
bile. | 


După terminarea acestui program se poate restaura vechea valoare a PC de 


pe stivă, pentru a relua programul abandonat. NMI este singurul semnal al micro- 
procesorului Z80 care datorită importanţei: sale (trebuie evitată posibilitatea tre- 


cerii neobservate a unei cereri NMI) nu se activează pe nivel, ci pe front. 
Cererea NMI se înregistrează la apariția unui front scăzător pe acest semnal, 
cerere care va persista pînă la acceptare (sfîrşitul instrucţiunii în curs), chiar 
dacă între timp cererea în sine a dispărut. 
Evenimente importante care merită să fie semnalate prin NMI sînt : avertis- 
ment la căderea tensiunii sau intervenție operator. 
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BUSRQ (BUS — ReQuest — cerere de magistrală) este „piciorul pus în 
prag'' de către un element din sistem, manevră prin care se suspendă micro- 
procesorul. Acesta din urmă va termina ciclul mașină în curs de execuție, după 


care emite semnalul de acceptare a cererii: BUSAK, și va „sta deoparte” cu 
toate magistralele puse în starea de înaltă impedanţă (cedate). În această situație 
dispozitivul care a suspendat microprocesorul va prelua comanda magistralelor din 
microcalculator. Această facilitate poate fi folosită pentru a realiza un sistem cu 
două procesoare diferite, din care doar unul să fie activ, sau pentru a realiza un 
dispozitiv cu acces direct la memorie, Un dispozitiv DMA poate efectua un trans- 
fer mai rapid între un echipament periferic și memoria microcalculatorului, decît 


ar putea-o face microprocesorul prin program. BUSRQ este activ în starea 0, 


RESET  (Reiniţializare ) este ,,mîna de ajutor'' acordată de către operator 
microprocesorului (sau de către proiectanții microprocesorului — operatorului ?!), 
Acest semnal permite reinițializarea microprocesorului. La activarea lui (valoarea 0) 
se întîmplă următoarele evenimente în interiorul microprocesorului : 


— se șterge contorul program PC =0000H 
— se inhibă sistemul de întreruperi IFE1==FR2=0 
— se stabilește regimul de întreruperi IM O 

— se inițializează regiștrii | și R 1l=R=00H 


Semnalul RESET se va aplica microprocesorului la „trezire'' (după pornirea 
de la butonul rețea al unui dispozitiv cu microprocesor) și oricînd execuția unui 
program „s-a rătăcit”! sau a intrat într-o buclă infinită. 

Pentru a fi luat în considerare, semnalul RESET trebuie să fie activ minimum: 


3 tacți procesor. Pe durata aplicării semnalului RESET=0 magistralele de date 
şi adrese ale microprocesorului Z80 trec în stare de înaltă impedanţă (tri- state) 
iar semnalele de comandă în stare inactivă (1 logic). În acestrăstimp „nimeni 
nu lucrează, deci nu vor exista ciclurile de reîmprospătare a memoriei (RFSH), 

Orice încercare de a realiza un sistem în care aceste- legături inverse, teed— 
back, lipsesc ar fi sortită eșecului. Dacă aceste semnale nu există, sau dacă ele 
nu sînt luate în considerare nu poate rezulta nimic altceva decit un sistem rigid 
ce nu se adaptează la condițiile schimbătoare ale mediului său înconjurător, un 
sistem în care ideea de siguranță primează asupra criteriilor de performanţă. 
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3 


SETUL DE INSTRUCȚIUNI 


Totalitatea instrucțiunilor pe care un microprocesor le poate recunoaşte și 
executa, formează setul de instrucțiuni al microprocesorului respectiv. 

Dacă am fi puși în situația — și în realitate ni se întîmplă destul de des 
— să comparăm două microprocesoare pentru a-l alege pe cel mai performant, 
sau pe. cel care se pretează mai bine pentru rezolvarea problemei noastre, nu 
vom recurge la o analiză comparativă a seturilor lor de instrucțiuni. Pe lîngă 
spațiul de adresare, lățimea magistralei de adrese, numărul regiștrilor interni și 
frecvența maximă de tact, calitatea setului de instrucțiuni este aceea care deter- 
mină în ultimă instanță performanța unei unităţi centrale de calculator și implicit 
și pe cea a unui microprocesor. 

Cu cît setul de instrucțiuni este mai mare, cu.cît el este mai variat — dis- 
tingîndu-se cît mai multe clase de instrucțiuni —, cu cît tehnicile de adresare 
folosite sînt mai bogate, cu atît mai multe tipuri de probleme se vor putea rezolva 
în mod flexibil și eficient, cu atît mai performant va fi microprocesorul în cauză. 

Pentru a da un exemplu sugestiv în acest sens — rămînînd în lumea micro- 
procesoarelor de 8 bit — vom compara în linii mari cei doi corifei, micro- 
procesorul 18080 al firmei Intel și Z80 al firmei Zilog, analizînd seturile lor de 
instrucțiuni. 

În primul rînd totalul instrucțiunilor : 18080 recunoaște și execută 244 de 
instrucțiuni, pe cînd Z80—696 declarate de către fabricanți și încă cîteva sute 
nedeclarate, a căror existență a fost descoperită întîmplător de unii utilizatori, 
sau dedusă logic din analiza codurilor, de către alții. 

Dacă amintim că Z80 este compatibil de sus în jos cu 18080, adică execută 
toate instrucțiunile acestuia în mod identic, fără nici un fel de modificări, atunci 
şi această primă comparație ar fi suficientă pentru a-l alege ca cel mai bun. 

Continuăm totuși comparativ, nu atît pentru a savura victoria repurtată de 
către alesul nostru, ci mai mult pentru a introduce cîteva noțiuni. noi. 

e Pe cînd 18080, — exceptînd două instrucțiuni — operează numai pe 
octeți, Z80 dispune de 240 instrucțiuni care tratează selectiv biții dintr-un octet 
și de 16 instrucțiuni care vehiculează blocuri de date, a căror lungime poate atinge 
valoarea de 65.536 octeți. 

e Pe cînd 18080 poate efectua doar patru tipuri de rotiri sau deplasări asupra 
unui octet — și el locat obligatoriu în registrul acumulator A — , Z80 recu- 
noaște 941 tipuri de astfel de instrucțiuni, şi ele pot opera asupra conţinutului 
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SETUL DE INSTRUCȚIUNI 


oricărui registru de uz general, ba chiar mai mult folosind tehnici de adresare 
speciale, chiar și asupra conținutului oricărei locații de memorie. 

O Pe cînd 18080 poate executa un singur tip de operaţie aritmetică (adu- 
nare) asupra unor regiștri dubli (cuvinte de 16 biţi), Z80 recunoaște trei tipuri 
de instrucțiuni de același fel, și efectuează pe lîngă adunare și scăderea. 

e Pe cînd 18080 poate calcula direct doar complementul față de 1 al unui 
octet, Z80 ne oferă prin instrucțiunea sa NEG și complementul față de 2 al unui 
byte. 
4 e În fine, pe cînd 18080 execută toate transferurile la dispozitive de intrare/ 
ieșire prin registrul acumulator A, Z80 le poate realiza „„via'' oricare din regis- 
trele sale de uz general, ba chiar mai mult direct între memorie și dispozitivul 
de intrare/ieșire. 

Trecînd la compararea tipurilor de adresare folosite, constatăm că micropro- 
cesorul 18080 cunoaște 4 tipuri: implicit, imediat, indirect („via” registru) şi 
direct absolut. Z80 aduce în plus 3 noi tipuri de adresare: indexat, indirect 
(„„via”' memorie) și direct relativ. 


Tot la compararea tehnicilor de adresare amintim faptul că dacă 18080, prin 
„propria-i forță” fără alte resurse hardware constituite de utilizator, poate adresa 
256 de porturi de ieșire și tot atîtea de intrare, Z80 „vorbește”' nemijlocit cu 
2 X 65536 de asemenea dispozitive. Un număr imens, de altfel.. Nu cunoaștem 
să se fi realizat undeva în lume un microsistem bazat pe un microprocesor de 
8 biţi (Z80), care să fi avut atîtea dispozitive de intrare/ieșire. 


Conchidem prin a constata un lucru evident: misiunea noastră, de a-l alege 
pe cel mai performant dintre cele două microprocesoare, a fost în acest caz 
deosebit de ușoară. Probabil că dacă vom dori pe viitor să comparăm alte micro- 
procesoare, vom avea mai multă bătaie de cap. De aceea, vom explicita cîteva 
din noțiunile deja folosite. 


3.1. Formatul instrucțiunilor 


Așa cum am arătat în capitolul introductiv, codurile instrucțiunilor direct 
executabile de către microprocesor nu sînt altceva decît numere binare. Fiecare 
cod declanșează, după decodificarea sa în circuitul de comandă al microprocesorului, 
o serie de activități ce converg spre efectuarea „,poruncii” transmise de către 
acel cod. Se pune de asemenea întrebarea : ce lungime (îți biți sau octeți) tre- 
buie să aibă numărul binar (cuvîntul de cod) pentru a defini univoc o instruc- 
țiune ? În cazul microprocesorului 18080, a cărui set de instrucțiuni numără 244 
de comenzi posibile, 8 bit se dovedesc a fi suficienți căci cu ajutorul lor se pot 
scrie 28 — 256 de numere binare distincte. Cele 696 de instrucțiuni declarate 
ale microprocesorului Z80 necesită în schimb un cuvînt binar mai lung. 10 bit 
vor ajunge desigur : 219 = 1024 combinaţii posibile. Datorită faptului că structura 
microprocesorului este orientată pe byte (8 bit), şi memoria care i se atașează, 
va conţine cuvinte avînd lungimea de 1 octet. Ar fi inconvenabil, ba chiar foarte 
greu de realizat, o structură care să trateze coduri de 10 bit și date de 8 bit, 
cu atît mai mult cu cît ambele circulă pe aceeași cale : magistrala de date a micro- 
calculatorului. De aceea pentru a codifica un număr mai mare de instrucţiuni 
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decît '256 s-a recurs la o tehnică specială : unele instrucțiuni vor fi reprezentate 
pe doi octeți. : 

În setul primar de coduri (numere cuprinse între 0—256) se nominalizează 
cîteva, ele urmînd să fie coduri rezervate. La citirea unui cod rezervat, micro- 
procesorul va sesiza că pentru a înțelege porunca codificată el trebuie să mai 
citească un octet de cod din memorie. Fiecare cod rezervat mărește astfel totalul 
instrucțiunilor codificate cu 256. Dorind să fim riguroși, vom nota cu n numărul 
codurilor rezervate adoptate. Atunci totalul instrucțiunilor codificabile prin această 
tehnică devine : 


N=256—n$+n-x 256 =256+n x 255 


Folosind 2 coduri rezervate s-ar fi putut implementa cele 696 de instrucțiuni. 
Pentru a simplifica în oarecare măsură electronica circuitului de comandă, care 
va trebui să înţeleagă instrucțiunile — decodificîndu-i codurile —, proiectanți 
microprocesorului Z80 au rezervat 4 coduri. Ele sînt: 


CBH, DDH, EDH, FDH 


Ori de cîte ori într-o secvență de instrucțiuni apare unul din numerele de 
mai sus, octetul care îl urmează va fi de asemenea cod de instrucțiune, instruc- 
țiunea fiind astfel definită de ansamblul celor două coduri. 

Folosind 4 coduri de rezervă, totalul instrucțiunilor codificabile devine 1276. 
Cele 1276 — 696 = 570 combinaţii redundante stau la originea instrucțiunilor 
„„ascunse”' ale microprocesorului Z80, instrucțiuni asupra cărora vom reveni în 
Cap. G. (COMPLEMENTE) 

Din cele relatate deducem că instrucțiunile microprocesorului pot ocupa un 
număr variabil de octeți în memorie. 

Să vedem cîți octeți se folosesc, care este deci formatul instrucțiunilor micro- 
precesorului Z80'! 

Știm deja că Z80 are 252 de instrucțiuni care se codifică pe un octet. Să fie 
deci 1 numărul octeţilor care trebuiesc rezervaţi în memoria calculatorului, pentru 
a descrie aceste instrucțiuni ? 


lată un exemplu: 
LD H,B 


Instrucţiunea înseamnă: încarcă registrul H cu conținutul registrului B. 
Codul instrucţiunii : 60H va conţine toate informaţiile necesare pentru execuţia 
acestei instrucțiuni. 

Dar ce ne facem cu următorul exemplu? 


LD H, 73n 


Această instrucțiune s-ar traduce în felul următor : încarcă registrul H cu 
valoarea 73, sau într-o formulare mai generală LD r, n unde r poate fi oricare 
registru de uz general (cu lățimea de 8 bit) și n un număr binar oarecare expri- 
mat de asemenea pe un octet. Apare de la sine întrebarea : Unde se memorează 
cctetul de date n (73, în exemplul de sus), pentru ca microprocesorul să poată 
localiza uşor acest parametru, după ce a citit și înţeles codul instrucţiunii ? 
Soluţia cea mai convenabilă este de a așeza byte-ul de date la adresa de memorie 
imediat următoare celei care conţine octetul de cod. Această tehnică numită 
adresare im ediată, duce la un necesar de 2 octeți pentru descrierea instrucţiunii, 


A0 


dintre care unul de cod și unul de date. Conţinutul celor doi octeți pentru ins- 
trucțiunea enunțată va fi deci : 264, 73u. 

Din prezentarea structurii interne a microprocesorului reținem faptul că 
regiștri simpli (1 octet) luaţi cîte doi, pot forma regiștri dubli (2 octeți) şi că 
evident, există instrucțiuni care îi tratează ca atare. 

Să considerăm cel mai elementar exemplu în acest sens: 


LD HL, 12344 


Încarcă registrul dublu HL cu valoarea hexazecimală 12344, sau într-o for- 
mulare generală : LD rr, nn unde rr poate fi unul din regiștrii dubli ai micropro- 
cesorului, iar nn orice număr binar de 16 bit (2 octeți). Ca și în cazul precedent, 
folosind tehnica de adresare imediată, cei doi octeți de date nn vor fi locaţi 
în memorie la adresele imediat următoare octetului de cod. Mai rămîne de lămurit 
doar ordinea în care se vor memora cei doi octeți. Cu o perseverență demnă 
de invidiat, ori de cîte ori în memorie se va scrie un cuvînt (16 bit) de date, 
octetul mai puțin semnificativ se va stoca la adresa inferioară, iar octetul cel 
mai semnificativ la adresa superioară. Amintim aici că aceeași regulă va fi respec- 
tată și de către instrucțiunea PUSH BC de exemplu, instrucțiune care salvează 
în memorie, începînd cu adresa indicâtă de indicatorul de stivă SP, conținutul 
registrului dublu BC: registrul C conținînd octetul mai puțin semnificativ al 
cuvîntului se va salva la adresa inferioară iar octetul cel mai semnificativ, din B, 
la adresa următoare. (În tehnica de calcul legile sînt făcute pentru a fi respec- 
tate !). Instrucţiunea prezentată va ocupa în memorie trei octeți, dintre care 
primul reprezintă codul și următorii doi datele: 


214 345, 12 
Dacă am dori să încărcăm în aceeași manieră registrul dublu IX 
LD IX, 12344 
vom necesita 4 octeți : 
DD,, 21, 34, 12u 


În acest caz primii doi octeți reprezintă codul operației iar următorii dai data. 
Specificînd că se pot imagina și alte combinații, sintetizăm formatul instruc- 
ţiunilor. 
Instrucţiunile microprocesorului Z80 pot ocupa în memorie 1,2, 3 sau 4 
octeți în următoarele combinaţii posibile: 


1 octet : = 1 octet de cod ex. : LD H,B 
2 octeți : = 1 octet de cod + 1 octet de date ex. : LD H,73y 
= 2 octeți de cod ex. : LDI 
3 octeți : = 1 octet de cod + 2 octeți de date ex. : LD HL, 1234, 
= 2 octeți de cod + 1 octet de date ex. : LD B, (IX+IND) 
4 octeți : = 2 octeți de cod + 2 octeți de date ex. : LD IX, 1234, 
= 3 octeți de cod + 1 octet de date ex. : BIT 5, (IY+IND) 
Putem să stabilim și cîteva reguli : 


1, Ori de cîte ori într-o instrucţiune este implicat un registru de index IX sau IY, 
codul aferent instrucţiunii se va reprezenta pe doi sau trei octeți. Primul octet va fi obli- 
gatoriu DD,, pentru registrul IX şi FD, pentru IY. 
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2. Referirea la regiștrii index IX şi IY se face cu coduri identice cu cele pentru regis- 
trul HL, precedate de codul rezervat DD,, sau FD,,. 

3. instrucţiuni orientate pe bit (BIT, SET, RES) şi cele din clasa rotirilor şi deplasă- 
rilor cu poziționarea indicatorilor de stare (RLC, RRC, RL, RR, SLA, SRA, SRL) ocupă în 
memorie 2 sau 4 octeți (2 octeți de cod respectiv 3 octeți de cod și unul de date). Excep- 
tînd cazul în care ele implică regiștri de index IX și IY, primul octet de cod este CB,,, 


La folosirea regiştrilor de index, codul CB,, apare — aşa cum rezultă din regula 1 — pe 
poziţia a doua. 

4. Instrucţiunile multiple (LDI, LDD, LDIR, LDDR, CPI, CPD, CPIR, CPDR, INI, 
IND, INIR, INDR, OUTI, OUTD, OTIR și OTDR) se codifică pe doi octeți de cod, în care 
primul este obligatoriu ED,,. 

5. Indicele IND utilizat pentru adresarea — folosind tehnica indexată — a unui octet 
din memorie, reprezintă un deplasament exprimat pe un octet față de o adresă de bază, 
conținută în IX sau IY, iar în cîmpul instrucţiunii valoarea lui apare obligatoriu pe poziția 
imediat următoare codului CB,. Astfel apare situația curioasă în care într-o instrucțiune de 


4 octeți (3 cod + 1 data) cel de-al 3-lea cod (cel care specifică ceea ce este de fapt de făcut) 
apare pe ultima poziție, precedată de o dată. Un exemplu în acest sens îl constituie instruc- 
ţiunea BIT 5, (IY + IND), dată ca exemplu mai sus, a cărei structură este: 

COD1, COD2, DATA, COD3 

FDH, CBH, IND, 76H 


În exemplele pe care le-am citat de-a lungul plictisitoarelor pagini de pînă 
aici, ne-am referit adesea la tehnici sau tipuri de adresare folosite de către 
microprocesor, specificînd că ele reprezintă caiacieristici importante în tehnica 
de calcul. 

Să le cunoaștem atunci! 


„Mașina va putea să modifice conținutul memoriei, ba mai mult, acesta este 
regimul normal de lucru al calculatorului. Astfel, mașina va fi capabilă să modifice 
instrucţiunile stocate în memorie — aceleași instrucțiuni care guvernează însăși acti- 
vitatea sa — putindu-se realiza pe această cale structuri de instrucțiuni oricît de 
complexe, care-și modifică în mod dinamic conținutul, și astfel şi procedurile de 
calcul pe care le are de efectuat". 

Afirmația, care la începuturile tehnicii de calcul moderne părea puţin ciu- 
dată, dacă nu bizară de-a dreptul, s-a adeverit cu trecerea timpului. 

În anii noștri există calculatoare care încearcă, dir; ce în ce cu mai mult 
succes, să-l substituie pe om în munca sa cea mai intelectuală: cea de concepție 
şi cea de luare a unor decizii. Bineînţeles, că nu atît structura hardware a cal- 
culatoarelor amintite, ci mai degrabă programele implementate (software-ul) rea- 
lizează aceste funcţii. Aceste pachete de software au o trăsătură esenţial nouă 
față de programele uzuale: ele au prevăzute secvențe și regimuri de autoin- 
struire. Nu putem să acceptăm ideea unui sistem expert de exemplu, care, dacă 
prognoza dată de el nu s-a adeverit decît în măsură de 70%, să nu fie capabil 
să învețe din cele întîmplate, să se autoinstruiască. Cum vor proceda într-o 
asemenea situație programatorii, cei care au elaborat sistemul expert în cauză ? 
n nici un caz nu vor rescrie programele! Ele au fost astfel concepute, încît, 
atașînd prognozei calculate de ele situația reală, precum şi o descriere formală 
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a cauzelor care au condus la generarea prognozei inexacte, programele își vor 
recalcula automat parametrii de lucru — se vor autorestructura. Aceasta ar fi 
cea mai înaltă formă de materializare cunoscută pînă în prezent, a ideii neuman- 
niene, lansată încă în anii 1940. 
Nu încercăm să detailăm structura programelor de inteligenţă artificială. 
Am apelat la această paranteză pentru a îndrepta atenţia către importanța 
dotării unui calculator cu cît mai multe tipuri de adresare posibile. 


Aşa cum am văzut, și după cum vom vedea în cele ce urmează, majoritatea 
instrucțiunilor lucrează cu unul sau mai mulți operanzi. 

Modul în care acești operanzi sînt aduși la cunoștința unității centrale (micro- 
procesorului), calea pe care i se comunică adresa la care se află locat operandul 
căutat, se numește tehnică de adresare. 

Modul cel mai rudimentar, de a introduce un număr într-o secvență program, 
este de a-i specifica direct valoarea, cum ar fi și cazul instrucţiunii : 


JP 5487, 


În cazul de față se va executa oricum un salt la adresa 5487,. Tehnica pe 
care am folosit-o, s-ar putea numi adresare directă, fiindcă specificăm în mod 
direct adresa la care se va efectua saltul. Structura unui astfel de program este 
rigidă : saltul se va efectua mereu la aceeași adresă. Desigur, pentru a mări 
flexibilitatea secvenței de program care se termină cu un salt necondiționat, 
fără a modifica de fiecare dată conținutul instrucţiunii, ar trebui să putem spe- 
cifica adresa de destinație a saltului, în mod indirect, de exemplu folosind în 
acest scop conţinutul unui registru dublu. 


Dispunem și de această posibilitate : 
JP (HL) 


Folosind instrucțiunea aceasta, saltul poate fi dirijat prin conținutul registrului 
dublu HL, conţinut care reprezintă de fapt adresa de destinație a saltului program. 
Observăm că astfel am cîștigat în mod considerabil în flexibilitate : registrul HL 
poate fi implicat în operaţii aritmetice/logice, conținutul lui putînd fi rezultatul 
unor calcule oricît de complexe. Folosind această a doua formă a instrucţiunii de 
salt necondiționat, putem modifica secvențele de rulare a programului și impli- 
cit și efectul lui, fără a modifica conținutul (imaginea de memorie) instrucţiunii. 

Instrucţiunea prezentată folosește tehnica de adresare indirectă. Specificăm 
că adresarea este de tip „indirect prin registru" căci există și adresare de tip 
„indirect prin memorie” unde adresa căutată se obține din două locații de memo- 
rie şi nu dintr-un registru dublu. Acesta este cazul la acceptarea unei întreruperi 
în modul 2 (1M2), cînd adresa de început a rutinei de tratare a întreruperii se 
obţine din 2 celule de memorie, care la rîndul lor nu au o adresă fixă în memo- 
rie, ci vor fi locate pe baza conţinutului unor altor registre (vectorul de între- 
ruperi provenind din registrul | şi perifericul apelant). Vedem deci că în procesul 
de determinare a adresei de început a unei rutine de tratare a întreruperilor în 
mod IM2, microprocesorul recurge la o adresare dublu indirectă: indirectă prin 
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registru (vector) pentru determinarea adresei adresei și apoi indirectă prin memo- 
rie pentru determinarea adresei efective de salt. 

Ce se întîmplă însă cu cele 2 instrucțiuni de salt prezentate, dacă dintr-un 
motiv oarecare vom dori să dislocăm programele în care apar instrucțiunile amin- 
tite, într-o altă zonă de memorie ? Evident, cele două instrucțiuni — dar mai 
ales prima — vor da greș, datorită faptului că prin dislocare s-a modificat probabil 
și adresa de destinaţie a saltului. 

Peste un asemenea inconvenient se poate trece folosind o instrucțiune de 
salt relativ : 


JR +20 de exemplu. 


Efectuarea acestei instrucțiuni va genera un salt necondiționat, a cărui des- 
tinație se calculează însumînd valoarea curentă a registrului PC (contor de pro- 
gram) și deplasamentul specificat în enunţul instrucţiunii (420 în cazul de față). 

Este evident faptul că această instrucțiune va funcționa corect, indiferent de 
zona în care va fi locat programul care o conţine. 

Tehnica de adresare folosită este relativă și directă : relativă fiindcă operandul 
se specifică relativ față de o valoare curentă (variabilă) și directă, fiindcă deplasa- 
mentul se specifică explicit în cîmpul instrucţiunii. Un cîștig suplimentar de flexi- 
bilitate ar putea oferi o instrucțiune care să folosească tehnica de adresare rela- 
tivă și indirectă : 

jr (€) de exemplu. 


Această instrucțiune ar trebui să efectueze un salt la adresa ce se obține 
însumînd valoarea curentă a contorului program și cea a registrului C. Din păcate 
setul de instrucțiuni al microprocesorului Z80 nu conţine o astfel de instrucțiune. 
(De aceea am și notat mnemonicile instrucţiunii cu litere mici). 

Dar să trecem la o prezentare metodică a tipurilor de adresare, înainte ca 
cititorul să rămînă cu falsa impresie că această noțiune s-ar referi doar la instruc- 
țiunile de salt. 


În literatură nu se găsește un consens general privind definirea, denumirea 
și clasificarea tipurilor de adresare. 

De aceea, descătușați, vom defini prin analiza problemei date, tipuri de 
adresare posibile, invitîndu-l pe cititor la o participare efectivă și afectivă. 

Să recapitulăm deci problema de rezolvat: 

Trebuie să analizăm modalitățile prin care se poate specifica tot ceea ce este 
necesar pentru locarea unei date, pe parcursul execuției: specificarea unui 
operand. 

Inainte de a trece la analiză reamintim faptul că, codul unei instrucțiuni 
trebuie să conțină și informaţii asupra a ceea ce are de făcut instrucțiunea res- 
pectivă, nu numai adresa datelor implicate în ea. 

Pe de altă parte reținem că adresarea regiștrilor, a celulelor de memorie şi 
a dispozitivelor de intrare/ieșire diferă esenţial. 

Datorită numărului în general redus al regiștrilor interni ai unui micropro- 
cesor adresele lor pot fi codificate pe cîțiva biţi. pe cînd adresarea unei celule 
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de memorie necesită generarea unei adrese al cărei număr de biți este egal cu 
numărul de linii de adresă a microprocesorului. În cazul microprocesorului Z80 
avem următorii regiștri simpli A, B, C, D,E,H,L, care fiind 7 la număr, adresele 
lor pot fi codificate pe 3 bit (2% = 8). Spaţiul de memorie adresabilă fiind 2'5= 
= 65536, pentru a adresa o celulă de memorie dată, este necesar să formăm o 
adresă de 16 bit. Pentru adresarea unui dispozitiv de intrare/ieșire este necesară 
o adresă de cel puţin 8 bit. De aici rezultă o diferență esențială : codurile instruc- 
țiunilor microprocesorului Z80 avînd lungimea de 8 bit, pot încorpora adresa unui 
registru intern dar nicidecum adresa unei celule de memorie sau a unui dispo- 
zitiv de intrare/ieșire. 

Şi acum să trecem la treabă: 

Privind problema în modul cel mai general posibil, constatăm : o instrucțiune 
poate încorpora data dorită, sau adresa datei dorite. De aici încolo vă rugăm 
să urmăriți arborele din fig. 3.1. 

Şi cum „toate drumurile duc la Roma”, tot așa și diversele ramuri ale arbo- 
relui nostru ; fiecare ramură finală reprezintă un tip de adresare. Structura arbo- 
relului este destul de neuniformă, iar criteriile de ramificație destul de etero- 
gene, pe alocuri chiar empirice. Acest fapt nu este o întîmplare, ci este o conse- 
cință firească a tentativei noastre de a dirija astfel structura arborelui încît la 
ieșire să obținem tipurile de adresare, așa cum ele sînt 'definite și clasificate în 
diversele referințe bibliografice. Semnele de întrebare semnalează tehnici de 
adresare posibile, neexplorate la scară largă pînă în prezent. Ele pot reprezenta 
pentru cei mai ambiţioși dintre d-voastră, puncte de reper în eventuala proiec- 
tare a unui nou tip de unitate centrală sau microprocesor, 

Cei care au avut răbdarea să Maite) cu atenție ramurile din figura de la 
pag. 46 se pot considera răsplătiți convingerea — la care sperăm să fi ajuns— 
că în clasificarea tipurilor de adresare folosite actualmente, există o dezordine 
considerabilă. 

Prezentăm pe scurt esenţa fiecăruia din cele 6 tipuri de adresare nominali- 
zate în figură, prin prisma unor instrucțiuni ale microprocesorului Z80. 


Adresarea imediată. Ori de cîte ori corpul unei instrucțiuni (nu codul) înglo- 
bează și data care reprezintă obiectul acelei instrucțiuni, adresarea folosită se 
numește imediată. 


Cîteva exemple în acest sens: 


a) LD A,55u pi 3Eu Ss 
| | | 
| | 
cod data 
| | 
] 
instrucţiune 


Instrucţiunea încarcă registrul A cu valoarea 55u. Data (55) este un octet de 
sine stătător, în cîmpul de doi octeți ai instrucţiunii. 
b) LD DE,GAF54 — 114 OO F5u 6Au 
| l 
joint aie A Pi 


cod data 
] | 


] 
instrucţiune 
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Instrucţiunea încarcă registrul dublu DE cu valoarea hexazecimală 6AF5,. Data 
(6AF5+) este un cuvînt de doi octeți în cîmpul de 3 byte al instrucţiunii. 
c) AND 8E,, — E6, BE, 
| (> &ţ | 
| | 
cod ' data 
! ! 


| 
instrucţiune 


Instrucţiunea execută o operație logică între conținutul registrului acumulator 
și numărul 8E,,. Data (8E,,) este un octet de sine stătător, în cîmpul de doi octeți 
al instrucţiunii. Acest tip de adresare este cel mai rigid posibil. Un programator 
versat va căuta să minimizeze numărul instrucțiunilor de acest gen în lucrările sale. 


Adresarea implicită. Dacă toate informaţiile necesare pentru locarea datei 
care reprezintă obiectul unei instrucțiuni, sînt încorporate în codul instrucţiunii, 
atunci adresarea se numește implicită. 

Observăm că o dată locată într-o celulă de memorie oarecare, nu poate fi loca- 
lizată prin această tehnică, deoarece adresa ei se codifică pe doi octeți. Cu atît 
mai mult datele locate în regiștrii microprocesorului, a căror adresă se codifică 
doar pe trei bit: 
Exemple de adresare implicită : 
a) LD C,D — 444 
Instsucțiunea transferă conținutul registrului D în registrul C. Atît adresa ini- 
țială a datei, cît și adresa ei de destinaţie sînt specificate în octetul de cod. Struc- 
tura byte-ului de cod este următoarea : 
poziţia bitului: b7 b6 b5 b4 b3 b2 b1 b0 
valoarea : D '54. 310 '':09109%410992 979 
semnificația : operația d2 di d0 s2 s1 s0 
unde : b7,b6(01) semnifică operaţia care se execută — transfer între regiștri ; 
d2,d1,d0(001) reprezintă adresa registrului de destinaţie, codificată pe trei 
bit; 
s2,s1,s0(010) reprezintă adresa registrului sursă, codificată pe trei bit. 
Amintim adresele codificate ale regiștrilor interni : 


000 — B 100 — H 
001 — C 101 — L 
010 — D 111 —A 
011 — E 


Remarcăm deasemenea faptul că pe parcursul execuției acestei instrucțiuni au 
loc două adresări : 

— una pentru citirea datei din registrul D 

— a doua pentru înscrierea datei în registrul C 


Observaţie : şi în cazul exemplului a) de la adresarea imediată există o adresare implicită : 
adresa registrului care se încarcă (A) este încorporată în codul instrucţiunii (3EH). Consta- 
tarea este valabilă și pentru exemplele b) şi c) enunțate. De altfel marea majoritate a instruc- 
țiunilor microprocesorului efectuează două adresări (destinaţie + sursă, sau operand 1 şi ope- 
rand 2, sau destinaţie + operand). De aceea în filele de instrucţiuni, care apar în partea Com- 
ei! priză vom specifica tipul de adresare folosit în ambele momente de execuție a instruc- 
ţiunii. 
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b) El — FB+ 

Instrucţiunea validează sistemul de întreruperi al microprocesorului, înscriind 
valoarea 1 în bistabilele IFF, și IFF,. Aceasta este una din puținele instrucțiuni 
care folosesc un singur tip de adresare și numai o singură dată. În cazul de față 
ea este bineînțeles implicită. . 

c) ADD HL, BC — 09, 

Acesta este un exemplu de adresare implicită luat din clasa instrucțiunilor arit- 
metice de 16 bit. Conţinutul registrului dublu HL este adunat cu cel al regis- 
trului dublu BC. Şi în acest caz, ambii operanzi se specifică implicit, în octetul 
de cod. 

d) LD DE, 6AF5, — 11, F5u 6AH 


Am reluat acest exemplu pentru a rememora faptul că pe parcursul execuției 
instrucţiunii, întîlnim atît adresarea implicită — la specificarea adresei registrului 
destinaţie, inclusă în codul 114 — cît şi adresarea imediată — folosită pentru 
specificarea datei (6AF5,) de transferat. 


Adresarea indirectă. Dacă adresa unui operand este conținutul unui registru 
sau a unei locaţii de memorie, tehnica de adresare se numește indirectă. 
Adresarea indirectă „via'”' memorie se întîlnește într-un singur caz : atunci cînd 
Z80 acceptă o întrerupere în modul 2, adresa de început a subrutinei de tra- 
tare a întreruperii este determinată folosind această tehnică. 

Exemplele de adresare indirectă sînt mai numeroase. lată cîteva: 

a) ADC (HL) — 8E 

Instrucţiunea adună la conținutul acumulatorului, numărul stocat în memorie, 
la adresa conținută în registrul dublu HL, iar apoi este adăugată și valoarea 
bitului de transport (carry). 

În realitate și această instrucțiune conţine adresări de mai multe tipuri: 

— 3 adresări implicite cuprinse în octetul de cod, pentru identificarea regis- 
trului A, a bitului Cy și a registrului de adresă HL. 

— 1 adresare indirectă pentru citirea unui operand din memorie, operand 
adresat prin conținutul registrului dublu HL. 

b) PUSH DE — D5u 

Acesta este un alt exemplu de instrucțiune, care folosește adresarea indirectă. 

Efectul ei este: conținutul regiștrilor D și E este salvat în memorie la adresa 

următoare din stivă, începînd cu registrul D. Adresa la care se face transferul 

este conținută în indicatorul de stivă SP, al cărui conținut este decrementat 

după fiecare transfer, 

Instrucţiunea folosește următoarele tehnici de adresare: 

— implicit: — de 3 ori; 2 pentru a specifica cei doi regiștri D și E, de unde 
se ia data și 1 pentru a specifica registrul de adresă SP 

— indirect : — adresa de destinaţie a transferului în memorie se ia din regis- 
trul SP. 

c) LD A,(BC) — 0A4 

Instrucţiunea încarcă conținutul registrului A, din memorie, de la adresa conţi- 

nută în registrul dublu BC. 


Instrucţiunea folosește atît adresarea implicită (pentru specificarea destinaţiei — 
registrul A) cît și adresarea indirectă (pentru a specifica adresa sursei — celula 
de memorie adresată prin conţinutul registrului dublu BC). 
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d) RST 08H — CFu 

Instrucţiunea efectuează un salt necondiționat la adresa 0008H, după ce în prea- 
labil salvase pe stivă (la adresa conținută în registrul SP) valoarea contorului de 
program PC. 

Instrucţiunea folosește adresarea indirectă (pentru salvarea în memorie a conţi- 
nutului PC) şi cea implicită pentru a efectua saltul. 


Adresarea directă. Dacă în corpul unei instrucțiuni apare o adresă, adresă 
care este adresa efectivă a datei ce constituie obiectul instrucţiunii, atunci adre- 
sarea se numește directă. 

Adresarea directă apare mai ales la instrucțiunile de transfer între regiștri şi 
memorie, precum și la instrucțiunile de salt. 

Folosirea instrucțiunilor ce utilizează acest tip de adresare, se va limita la un 
minim posibil, deoarece ele rigidizează programul. 

Pentru a putea rula în altă zonă de memorie decît cea originală, instrucțiunile 
din program, ce folosesc adresarea directă, vor trebui probabil modificate. 


Exemple : 


a) LD (1784,),A 7324, au 17, 


] | 
cod adresă directă 
| | 
| 
instrucţiune 

Această instrucțiune transferă conţinutul registrului A în memorie, la adresa 
1784. 
Adresarea folosită este implicită pentru determinarea sursei (reg. A) și directă 
pentru specificarea destinaţiei (adresa 17844). 


B) LD HL, (11224) — 2Au 224 11 
| 


— 


| 
cod adresă directă 
| | 
Î 
instrucțiune 


LD HL, 11224 — 21n 224 11n 
| pe 1] | 


| | 
cod dată 
] | 


l 
instrucţiune 


Am enunțat alăturat cele două instrucțiuni pentru a atrage atenția asupra peri- 
colului de confuzie, care apare la aceste două instrucțiuni. Întrucît ambele cîm- 
puri de instrucțiuni conțin un cod pe un octet și o valoare numerică pe doi octeți, 
am putea fi tentaţi să considerăm ambele cazuri, ca exemple de adresare imediată. 
Dar nu este așa. În prima instrucțiune 1122, este adresa datei care constituie 
obiectul instrucţiunii, pe cînd în cel de-al doilea exemplu 1122, reprezintă însăși 
data cu care operează instrucțiunea. 

LD HL, (1122) — conţine și o adresare directă ; 

LD HL, 1122,  — conține și o adresare imediată; 
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ambele conţin adresarea implicită pentru specificarea destinaţiei : registrul dublu 
HL. 


c) OUT (80H),A — D34 80, 


| | 
a adresă directă 
| 


| 
instrucţiune 


Instrucţiunea transferă conținutul registrului acumulator A la dispozitivul de 
ieșire care are adresa 804. Adresa sursei (A) este specificată implicit. iar cea a 
destinaţiei (portul cu, adresa 80) direct. 


d) CALL 77784 — CDu 78: 77n 
| Il | 


Ă 
co „adresă directă 


instrucțiune 


Instrucţiunea reprezintă un apel tipic de subrutine : conţinutul contorului program 

este salvat în stiva adresată de indicatorul de stivă SP, după care se execută un 

salt la adresa de început a: subrutinei (7778). 

Instrucţiunea folosește 3 tipuri de adresare: 

— implicită — pentru a specifica registrul SP care conţine adresa la care se va: 
face salvarea în memorie 

— indirectă — pentru a specifica adresa de memorie în care se va salva PC (con- 
ţinutul registrului SP) 

— directă  — pentru a specifica adresa la care se va efectua saltul. 

Păcat că proiectanţii microprocesorului Z8O n-au implementat și un apel de sub- 

rutină, la care adresa de salt să poată fi specificată și ea indirect. De exemplu 

prin conținutul registrului dublu HL. Apelurile de subrutină ar fi fost în acest 

caz mult mai flexibile. 


Adresarea relativă. Dacă adresa dorită a unei locații de memorie se obține 
adăugînd o valoare (oarecare) la conținutul curent al contorului program (PC), 
atunci adresarea se numește relativă. 


Exemplu : JR +05u — 184 034 
| i d | 


l | 
cod valoare (deplasament numeric) 
| | 


] 
instrucțiune 


Instrucţiunea execută un salt la adresa care se calculează însumînd valoarea curentă 
a contorului program PC cu valoarea (deplasamentul) inclusă în cîmpul instrucţiunii. 
Nu trebuie să ne deranjeze faptul că în enunţul instrucţiunii deplasamentul are 
valoarea +05, iar cîmpul cod 4+034. Diferența de 2 apare datorită faptului că 
dacă instrucțiunea este locată la adresa 100, de exemplu, atunci în momentul 
adunării deplasamentului, PC conţine deja 102. Astfel se vine în ajutorul pro- 
gramatorului care vede pe listing adresa de început a instrucţiunii. Transpunerea 
deplasamentului este efectuată automat de orice asamblor cît de cît „cinstit”. 
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Ce salturi relative frumoase s-ar fi putut executa dacă valoarea deplasamentului 
s-ar fi putut specifica nu numai imediat „(incluzînd-o î în corpul instrucţiunii) ci și 
indirect (de ex. prin valoarea conținută în registrul C) ! 

Din păcate Z80 nu cunoaște această posibilitate, 

Constatăm deci că instrucțiunea prezentată utilizează adresarea imediată pentru 
specificarea deplasamentului și adresarea relativă pentru determinarea adresei de 
salt. 

Dacă un program conţine numai salturi relative (și nu utilizează stivtzirea directă) 
atunci el poate rula la orice adresă de memorie, fără modificări. 


Adresarea indexată. Dacă adresa unei date, ce constituie obiectul unei instruc- 

țiuni, se obține adăugînd la un registru de bază (index), un ei it pi (indice) 
atunci adresarea se numește indexată. 
Z80 posedă 2 regiștri de 16 bit IX și IY, care pot fi folosiți ca regiștri de bază. 
Tehnica de adresare indexată este eficientă în cazul în care dispunem de date 
organizate într-un tabel, aidoma unei variabile cu indici. Regăsirea variabilelor 
cu indici trebuie să se poată face pur și simplu specificîndu- le indicele. i 
Considerînd că fiecare element din tabel ocupă un octet și că adresa de început 
(adresa de bază) a tabelului se încarcă în registrul index IX sau IY, atunci regă- 
sirea unei date dorite se poate. face specificîndu-i doar indicele. Microprocesorul 
va realiza automat suma dintre adresa de bază și indice, obţinînd astfel adresa 
fizică a datei căutate. 


Exemple : 
a) LD E, (IX + 254) — DDu 5Eu 25u 
| || | 


| | 
cod valoare (indice) 
| 


| 
instrucțiune 


Instrucţiunea transferă un octet din memorie în registrul E. Adresa celulei de 
memorie sursă se obține însumînd conţinutul registrului de bază IX și valoarea 
deplasamentului: +25 din cîmpul instrucţiunii. 

Instrucţiunea folosește adresarea implicită pentru a specifica regiștrii E şi IX, 
adresarea imediată pentru specificarea deplasamentului și adresarea indexată pentru 
obținerea datei -ce -constituie obiectul instrucţiunii. 


b) RES 7, (IY4+ 694) — FDu CBu 69 BE 
[Ed i i je i 
| | | 
cod valoare (indice) cod 
| 
] 
instrucțiune 


Instrucţiunea șterge (înscrie 0) bitul cel mai semnificativ al octetului din memorie, 

octet a cărui adresă se obține însumînd conţinutul registrului de bază (index) 

IY şi valoarea numerică (indice) 69, conținută în cîmpul instrucţiunii. Observăm 

că instrucțiunea ocupă 4 octeți din care trei octeți sînt rezervaţi pentru cod. 

Instrucţiunea folosește următoarele tehnici de adresare: 

— adresare implicită : pentru a specifica bitul afectat (7) și registrul de bază 
ce va fi folosit (1Y) 
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— adresare imediată : pentru a specifica valoarea deplasamentului, valoare inclusă 
în corpul instrucţiunii; 

— adresare indexată : pentru a calcula adresa fizică a octetului ce va fi mani- 
pulat (însumînd conținutul registrului de bază IY și deplasamentul 69,) 
Păcat că nu avem posibilitatea de a specifica deplasamentul în mod indirect (ex. 

conținutul registrului D). 

Atita timp, cît vom fi obligați să includem indicele numărului dorit în mod expli- 
cit în cîmpul instrucţiunii, va fi destul de greu să baleiem în mod selectiv o tabelă 
de exemplu. 

Facilitatea amintită nu este prevăzută în „logica cablată” a microprocesorului Z80. 
Ar fi totuși o posibilitate de a varia în mod dinamic, prin program, valoarea unui 
indice. 

Și anume: cunoscînd exact adresa locației de memorie care conține indicele 
situat în cîmpul instrucţiunii, putem concepe un program care să incrementeze 
sau să decrementeze, conform regulei dorite, conținutul acelei celule de memorie 
și astfel și indicele. Dar această metodă nu o recomandăm nici dușmanilor noștri. 
Din 2 motive: 

a) un asemenea program „,„moare subit'' dacă este transpus într-o memorie fixă 
(de tip ROM); 

b) urrnărirea, depanarea, service-ul unui program care își schimbă mereu instruc- 
țiunile este deosebit de greoaie. 

Din prezentarea tipurilor de adresare relativă și indexată (ca și din fig. 3.1 
de altfel) rezultă că cele două tipuri sînt aproape identice din punctul de vedere 
al mecanismelor pe care le invocă. Discriminarea celor 2 tehnici de adresare s-a 
făcut în cazul de față nu pe baza unor diferențe de ordin tehnic, ci mai degrabă 
pe baza noțiunilor de programare ce le-au fost asociate. Remarcăm deasemenea 
că în esență ele reprezintă un tip de adresare indirectă (,,via” registru) modifi- 
cat, în care adresa de memorie nu se obține nemijlocit dintr-un registru ci adu- 
nîndu-i o constantă numerică. Credem că fenomenul poate fi folosit ca un etalon 
de clasificare neriguroasă. Ea are rădăcini ce ţin de evoluția și istoria tehnicii 
de calcul. Am păstrat-o pentru a nu intra în flagrantă contradicție cu alte refe- 
rințe bibliografice, scutindu-l astfel pe cititorul novice de eventuale clipe de 
descumpănire. 

Există în schimb unele tipuri de adresare definite în documentația de firmă 
[MOSTEK] care nu le-am acceptat. 


În [30] p. 20—22 se enunță 10 tipuri de adresare. Le vom aminti pe cele 
pe care noi le-am respins, asociindu-le la una din cele 6 tipuri de adresare pre- 
zentate mai sus. A 

2. Immediate Extended Addressing (imediat extins ). În documentaţia de firmă 
instrucțiunile de tipul LD H, 124 și LD HL, 1234, sînt tratate ca instrucțiuni 
ce folosesc tipuri diferite de adresare: 

LD H, 124 — imediat 

LD HL, 1234, — imediat extins 
Noi considerăm că în esență ambele instrucțiuni folosesc adresarea imediată. Dis- 
criminarea lor este artificială și forțată. 
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3. Modified Page Zero Addressing (pagina zero modificată ) 

În această clasă sînt introduse instrucțiunile RST (restart) pe care noi le consi- 
derăm exemplul etalon de adresare implicită. Informaţia referitoare la adresa de 
salt a acestor instrucțiuni este introdusă sub formă codificată în însuși codul 
instrucţiunii. Faptul că salturile se efectuează în pagina 0 a memoriei (A0— 
A15 fiind cuprinse în limitele (0,255)), este un amănunt nesemnificativ din punc- 
tul de vedere al tehnicii de adresare folosite. 

7, Register Addressing (adresare de tip registru ) 

Toate instrucțiunile microprocesorului Z80 care implică numai regiștri interni, 
folosesc tehnica de adresare implicită în care informaţiile necesare pentru locarea 
operanzilor se încorporează în însuși codul instrucţiunii. Considerăm introducerea 
acestui tip de adresare ca nejustificată. 

10. Bit Addressing (adresare de tip bit). 

Instrucţiunile orientate pe bit (BIT, SET, RES) specifică numărul bitului afectat 
în însuși codul operației. De aceea noi considerăm că ele folosesc adresarea 
implicită, Întroducerea tehnicii de adresare tip bit, o considerăm inutilă. 
Tehnica de adresare pe care noi am numit-o directă, apare sub denumirea Exten- 
ded Addressing. Problema numelui acordată unui fenomen fiind o chestiune de 
gust, acceptăm şi această variantă. 

Credem că argumentele pe care le-am invocat pentru a valida deciziile luate, 
exclud orice dubiu privind justețea lor. 

Căutînd totuși o explicație pentru această clasificare insuficient de riguroasă 
nu găsim altă motivare decît cea pe care o etalăm în continuare. 

n primul rînd, sîntem convinși că această clasificare s-a preluat din prima 
documentaţie a microprocesorului Z80, publicată de firma Zilog în 1975, păstrîn- 
du-se nemodificată poate și datorită faptului că terenul tipurilor de adresare este 
destul de mlăștinos, datorită în primul rînd criteriilor de clasificare incoerente 
încetățenite de-a lungul anilor. 

Dar de ce au fost publicate, așa cum au fost, la prima publicare a documen- 
tației Z80? 

Este cert că cei care au lansat pe piață microprocesorul Z80 au dorit să aducă 
cît mai multe argumente în favoarea „odraslei” lor, sărind puțin peste cal. Zece 
tipuri de adresare înseamnă mult, foarte mult. Oare totalul instrucțiunilor 696, 
față de cele 244 ale marelui rival (18080), n-ar fi ajuns?! 

După ce i-am făcut cu ou și cu oţet pe cei de la Zilog, revenim la problemele 
noastre, trăgînd concluzia că o unitate centrală (microprocesor) este considerată 
a fi cu atît mai puternică, cu cît numărul tehnicilor de adresare pe care le cunoaște 
este mai mare și cu cît acestea sînt mai complexe — adresa (adresei (adresei 


214 00 00 23H 7Dun B4u C2u 034 01 C9u 

Şirul numerelor de mai sus nu este altceva decît un program scris în cod 
maşină. El efectuează cea mai lungă temporizare ce se poate realiza prin decre- 
mentarea succesivă a unui registru dublu de 16 bit. Această secvență de cod 
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poate fi executată direct atît cu microprocesorul 18080 cît și cu Z80 și este un 
exemplu de programare în cod mașină. 

Cu zece ani în urmă nu puţini ar fi fost acei colegi de-ai noștri care ar fi 
înțeles fără nici un fel de dificultate șirul codurilor mai sus enunțate. Nu pentru 
că ar fi avut o plăcere deosebită în a memora numere binare exprimate hexa- 
zecimal, ci datorită faptului că orice început de drum este greu, pionierii din- 
totdeauna fiind adesea obligați să-și irosească forțele tăind cărări printre stînci 
și construind cetăți de nisip pe terenuri mlăștinoase. Cam așa se scriau codurile 
direct executabile la începuturile calculatoarelor electronice. Continuînd pe acest 
făgaș programatorii microprocesorului 18080 ar fi fost obligați să rețină „„doar” 
244 de coduri de 1 octet. Cei care şi-ar fi asumat riscul de a programa micro- 
procesorul Z80 ar fi vehiculat 696 de coduri de 1,2 sau 3 octeți. Din fericire 
intelectul uman n-a tolerat multă vreme această sclavie, apropiind mai întîi codu- 
rile mașină de gîndirea și vorbirea curentă prin elaborarea limbajelor de asamblare 
și creînd apoi programe de translatare automată a instrucțiunilor, descrise în acest 
limbaj, în cod mașină. 

Codurile instrucţiunilor se formulează în limbajul de asamblare ca și cuvinte 
cheie — prescurtate de obicei — care exprimă funcția reprezentată de codul 
respectiv. Aceste cuvinte cheie se numesc mnemonici. 

Datele incluse în cîmpul instrucţiunii cod mașină, 'și cele pe care instruc- 
țiunile le invocă, apar în limbajul de asamblare ca și operanzi atașați mnemonicei. 
S-a creat astfel un mediu — limbajul de asamblare — în care libertatea de gîn- 
dire (a programatorului) a crescut considerabil, și o unealtă — programul de trans- 
latare, numit asamblor — care a sporit fără îndoială eficiența muncii de pro- 
gramare. 

Folosind mnemonicele microprocesorului 18080 programul cod mașină citat, 
se scrie : 


Mnemonicile microprocesorului Z80 exprimă aceeași realitate sub o formă 
puţin diferită : 


Povestea programului : încarcă registrul dublu HL cu 0; incrementează con- 
ținutul registrului HL cu 1 ; vezi dacă HL=0 ; dacă nu, atunci reia operaţiile de 
la incrementare (HL crește de la 0000, pînă la FFFFu, urmat de 00004); 
dacă nu, atunci gata. 

Remarcăm că fiecare microprocesor are limbajul său propriu de asamblare. 


Reținem că limbajul de asamblare este o imagine fidelă a setului de instruc- 
ţiuni, el exprimînd cît se poate de exact operaţiile elementare pe care o unitate 
centrală de calculator (sau un microprocesor) le poate executa. 

Între instrucțiunile limbajului de asamblare și codurile binare de instrucțiuni 
ale unui calculator există totdeauna o relație biunivocă : fiecărei instrucțiuni în 
limbaj de asamblare îi corespunde unul și numai un cod. 

Forma generală a unei instrucțiuni în limbajele de asamblare ale micropro- 
cesoarelor 18080 și Z80 este: 

Mnemonică Operand 1, Operand 2 

Operanzii sînt opționali : poate apare doar unul, sau pot lipsi. 


Exemple : 


2 operanzi MOV A,L LD A,L 
1 operand INX H INC HL 
0 operanzi RET RET 


Mnemonica este de obicei un nume generic și poate descrie mai multe 
instrucțiuni. În acest caz, instrucțiunile vor fi discriminate pe baza operanzilor 
atașați mnemonicei. 

Vom încerca în paragraful următor și în cap. E (COMPLEMENTE) să ordo- 
năm în diverse clase și grupe funcționale cele 696 de instrucțiuni ale micropro- 
cesorului Z80. 

Cei nerăbdători pot răsfoi de pe acuma paginile cap. E pentru a-și forma 
o imagine de ansamblu asupra setului de instrucțiuni ai microprocesorului Z80, 
și asupra mnemonicelor utilizate în limbajul de asamblare al acestui microprocesor. 


Pe baza funcției lor declarate, am împărțit cele 696 de instrucțiuni ale micro- 
procesorului Z80 în 12 clase distincte.* 

Claselor le-am acordat cîte un nume simbolic. 

În cadrul claselor am efectuat o subîmpărțire pe grupe de instrucțiuni. 

Redăm în continuare prezentarea condensată a claselor alese : 


Clasa 1. Instrucţiuni de transfer de 8 bit LOAD-—8 
(p. 278)  Mnemonici incluse:.LD 

Totalul instrucțiunilor din clasă : 111 

Numărul de grupe Săi, 
Clasa 2. Instrucţiuni de transfer de 16 bit LOAD — 16 
(p. 289)  Mnemonici incluse: LD,EX,EXX,POP,PUSH 

Totalul instrucțiunilor din clasă: 39 

Numărul de grupe : 10 
Clasa 3. Instrucţiuni de transfer de blocuri de date . LOAD— IDR 
(p. 301)  Mnemonici incluse: LDD,LDDR,LDI,LDIR 

Totalul instrucțiunilor din clasă: 4 

Numărul de grupe ti fre 


< Clasificarea aparține autorului 


Clasa 4.. 
(p. 303) 


Clasa 5. 
(p. 336) 


Clasa 6. 
(p. 343) 


Clasa 7. 
(p. 346) 


Clasa 8. 
(p. 353) 


Clasa 9. 
(p. 359) 


Clasa 10. 


(p. 366) 


Clasa 11. 


(p. 381) 


Clasa 12. 
(p. 389) 


Instrucţiuni aritmetice/logice pe 8 bit AR/LOG-—8 

Mnemonici incluse: ADD,ADC,SUB,SBC,AND,XOR,OR,CP,INC, 
DEC,CPL,NEG,DAA,RLCA,RRCA,RLA,RRA 

Totalul instrucțiunilor din clasă : 115 

Numărul de grupe 246 

Instrucţiuni aritmetice de 16 bit ARIT—16 

Mnemonici incluse : ADD,ADC,SBC,INC,DEC 

Totalul instrucțiunilor din clasă: 32 

Numărul de grupe E) 7 

Instrucţiuni logice pe blocuri de date LOG-—IDR 

Mnemonici incluse : CPD,CPDR,CPI,CPIR 

Totalul instrucțiunilor din clasă: 4 

Numărul de grupe: abuz 

Instrucţiuni orientate pe bit BiTSR 

Mnemonici incluse : BIT,SET,RES,SCF,CCF 

Totalul instrucțiunilor din clase : 242 

Numărul de grupe: vin 7 


Instrucţiuni de salt JUMP 
Mnemonici incluse : JP,JR,DJNZ 

Totalul instrucțiunilor din clasă: 18 

Numărul de grupe > 6 

Instrucţiuni de apel și revenire din subrutină CALL/RET 
Mnemonici incluse : CALL,RET,RST 

Totalul instrucțiunilor din clasă: 26 

Numărul de grupe 29 

Instrucţiuni de rotire și deplasare ROT/SHIFT 
Mnemonici incluse : RLC,RRC,RL,RR,SLA,SRA,SRL,RLD,RRD 
Totalul instrucțiunilor din clasă: 72 


Numărul de grupe: im 49 

Instrucţiuni de intrare/ieșire IN/OUT 
Mnemonici incluse : IN,IND,INDR,INI,INIR,OTDR,OTIR,OUT,OUTD 
Totalul. instrucțiunilor din clasă: 24 OUT! 
Numărul de grupe iai 

Instrucţiuni de comandă SYS 


Mnemonici incluse : DI,EI,HALT,IM,NOP,RETI,RETN 
Totalul instrucțiunilor din clasă: 9 
Numărul de grupe La 


În dreptul fiecărei clase am indicat paginile pe care se găsește descrierea 
detailată a instrucțiunilor aferente. 

Cei nerăbdători pot răsfoi de pe acum paginile respective precum și cele 
premergătoare lor ($ E.1) unde se regăsește și subîmpărțirea pe grupe a instruc- 
țiunilor din fiecare clasă tratată. 

n măsura în care numele pe care le-am ales pentru specificarea claselor şi 
a paginilor au fost suficient de sugestive, cititorul își poate forma deja o impresie 
asupra setului de instrucțiuni și implicit despre posibilitățile microprocesorului Z80, 


56 


Microprocesorul este, din punctul de vedere al modului de eșalonare în 
timp a activității sale, un dispozitiv sincron : toate manevrele sale interne și externe 
se întîmplă sincron (deodată) cu fronturile semnalului de tact (clock) care excită 
structura, „via'” pinul nr. 6 al capsulei. Privit de sus, de foarte sus, de unde totul 
pare ca un vis simplu și frumos, microprocesorul se arată a fi un element de rînd, 
a cărui activitate se poate reduce la două momente : 

a ) citește o instrucţiune din memorie 

b ) execută instrucțiunea citită 
După care totul începe de la început și se repetă. Aparent, monotonia acestei vieți 
este totală, amplificată parcă de adierea uniformă și zumzetul invariabil al venti- 
latorului menit să prelungească la nesfirșit o viaţă în care puţinele raze de soare 
se infiltrează prin gratiile fantelor de răcire, și sursele de alimentare menţin ten- 
siunea constantă. Dacă ar fi s-o vedem și s-o auzim (VISIBLE—Z80 ne-a permis 
-acest lucru) impresia noastră ar întări afirmaţia de sus. Un singur element pare 
suspect : vehemenţa mișcărilor din capsulă. Cei mărunți dau din mini și... le mișcă 
repede. De trei patru milioane de ori pe secundă! Să ne fi înșelat oare? Să fie 
ceea ce vedem, nu monotonie, ci extaz continuu ? Să fie oare deșertul doar o apa- 
rență, un voal după care se ascunde o viață exuberantă ? Asemenea optimistului 
înverșunat care nu se împotmolește niciodată, vom încerca să descoperim împreună 
frumuseţea amănuntelor, pentru a vă trezi pofta de ... citire, 


Am mai amintit, dar reluăm ideea că cea mai simplă instrucțiune se exe- 
cută în 4 perioade ale semnalului de tact, iar cea mai lungă în 23. Să luăm cîte 
un exemplu din cele două clase: 

4 taci: SCF — codul: 374 

23 tacţi: SET 0 (1X+594) — codul: DD+CB59+C6u 


Cele două instrucțiuni par a fi înrudite și totuși ce deosebire ! ambele înscriu 
valoarea 1 în cîte un bit al unui octet: SCF (Set Carry Flag — înscrie indica- 
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torul de transport) poziţionează la 1 bitul cel mai puțin semnificativ al regis: 
trului F, iar SET 0, (IX+IND) are același efect dar asupra unui octet locat îi 
memorie la adresa care se obține însumînd conținutul registrului dublu IX și 
valoarea 59. Cititorul atent a remarcat faptul că prima instrucțiune este des- 
crisă printr-un cod de 1 octet (374) pe cînd cea de a doua prin 4 octeți. 
Trecem la definiţii 


Definiţia 1. Entitatea care însumează toate activitățile care se desfășoară în timpul 
unei perioade a semnalului de ceas (tact) se numește ciclu sau stare de tact. (CC— Clock Cycle). 


Definiţia 2. Entitatea care reunește toate activităţile care se desfășoară pe parcursul 
execuţiei unei instrucțiuni a cărei cod este locat în memorie, se numește ciclu instrucţiune. 
(IC-Instruction Cycle). 


Pe cînd durata unui ciclu de instrucțiune variază de la o clasă la alta, durata 
ciclului de tact este unică pentru un microcalculator dat, perioada T a semna- 
lului de tact fiind unitatea de măsură a timpului elementar consumat de procesora 
Analizînd modul de execuție a celei de a doua instrucțiuni (SET 0, (1X+59,). 
observăm că cei 23 de tacți se compun din mai multe activități pe care în prim) 
aproximaţie le-am putea grupa astfel: 
1. Se efectuează 4 citiri din memorie pentru citirea instrucţiunii 

(DD, C3u 59 C6y). 
2. Se efectuează o citire din memorie de la adresa IX + 59,4 
3. Se rescrie la această adresă, octetul în care deia b, =0. 


Observăm că pentru a efectua instrucțiunea analizată microprocesorul va 
realiza 6 accese la memorie, din care 5 sînt de tip citire iar unul de tip scriere. 
Oricine își poate imagina că cele 5 activități de citire a memoriei sînt oricum 
activități înrudite. Este deci foarte probabil că în cursul efectuării instrucţiunii 
alese ca exemplu, microprocesorul va repeta de cîteva ori anumite secvenţe de 
lucru. 

În plus, asemenea activități se regăsesc la execuția majorității instrucțiun 
oricărei unități centrale. Pentru a conferi un plus de modularitate și flexibilita 
în execuția instrucțiunilor precum și pentru a ușura implementarea hardware-ul 
din chip, ciclul instrucțiune a fost subdivizat în cîteva tipuri de activităţi pro- 
cesor intermediare. 


Definiţia 3. Suma activităților procesor care  :zolvă o activitate intermediară bine 
definită, avînd o finalitate clară, în cursul execuţiei une instrucțiuni, se numește ciclu mașină. 
(MC-Machine Cycle). 


Considerentele care au dus la subdivizarea ciclurilor instrucțiune în cicluri 
mașină au fost de ordin tehnic, dar ele pot fi invocate și ca argumentare filozofic: : 
infinitul nu poate fi cuprins (exprimat) printr-o clasă infinită de elemente, scop 
deplin realizabil însă dacă se folosește o clasă cu un număr limitat de elemente 
judicios alese. Infinitatea tonalităților limbilor indo-europene pot fi formate şi 
exprimate prin seturi de litere (vocale și consoane) care derivă din cele doar 
26 litere ale alfabetului roman. Scrisul chinezesc însă, cel care folosește figuri 
descriptive în loc de litere, posedă o clasă de cîteva mii de elemente grafice, 
clasă care practic nu se va închide niciodată. Într-un mod similar: în loc de a 
realiza un circuit de comandă care să rețină 696 de secvențe distincte de acti- 
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vități, menite să implementeze setul de instrucțiuni al microprocesorului nostru, 
s-a recurs la stabilirea unor cicluri maşină puține la număr, cu ajutorul cărora 
realizarea circuitului de comandă al microprocesorului s-a simplificat considerabil. 
Care ar fi aceste activități tipizate (cicluri mașină) ? 

e Citirea şi decodificarea codului de operaţie (fetch) 

Ştim deja că o instrucţiune constă din 1—4 octeți, din care unul reprezintă 
obligatoriu codul de instrucțiune. Abia după citirea și înțelegerea (decodificarea) 
acestui cod, microprocesorul va şti ce are de făcut pentru a executa instrucțiunea. 

e Citirea unui octet de date (memory read). 


Datele numerice care apar în cîmpul unei instrucțiuni se citesc din memorie 
şi se depun într-unul din regiştri interni ai microprocesorului. Operația fiind mai 
simplă și deci mai scurtă în timp, decît cea precedentă a dus la realizarea a două 
tipuri de cicluri mașină de citire din memorie : 


— ciclu de citire a codului de operație (fetch) 
— ciclu de citire a datelor numerice (read) 


E Scrierea unui octet în memorie (memory write). 


Așa cum am remarcat și în exemplul analizat, anumite instrucțiuni vor în- 
scrie gate numerice în memorie. Ciclul mașină care rezolvă operația se numeşte 
ciclu mașină de scriere în memorie : write. 


Folosind aceste trei cicluri mașină, marea majoritate a instrucţiunilor micro- 
procesorului Z80 pot fi implementate. Există și cicluri speciale în activitatea pro- 
cesorului, dar ele vor fi tratate în cap. 8 şi cap. $ 


Sintetizăm funcționarea microprocesorului afirmînd : 

— instrucțiunile se execută în cicluri de instructiune (IC) ; 

— ciclurile instrucțiune sînt constituite dintr-un număr întreg de cicluri mașină 
(MC) ; 

— Ciclurile mașină sînt constituite dintr-un număr întreg de cicluri de tact (CC). 


Ciclurile maşină ale microprocesorului Z80 sînt: 
a) ciclul de citire al codului de operație (fetch) (M1) 
b) ciclul de citire al unui octet din memorie (read) 
c) ciclul de scriere al unui octet în memorie (write) 
d) ciclul de citire a unui dispozitiv de intrare (in) 
e) ciclul de scriere a unui dispozitiv de ieșire (out) 
f) ciclul intern 

g) ciclul de accaptare a cererii de întrerupere 

h) ciclul de acceptare a cererii de magistrale 


Frecvența de apariție a tipurilor a — c este mult mai mare decît a celorialte. 
De aceea le numim cicluri de bază. Le vom trata în prezentul capitol. 
În fig. 4.1 am reprezentat ciclurile de bază, folosind ca unitate etalon ciclul de 
tact T. 

Vom recurge în sfîrşit la VISIBLE—Z80, pentru a ilustra activitățile întreprinse 
de procesor în vederea efectuării instrucțiunilor, Așa cum se poate vedea în 
oricare dintre imaginile create cu VISIBLE— Z80, în partea din stînga sus a ecra- 
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ciclu 


a) 


Cidu instrucțiune 


(READ memorie ) 
Ciclu_instructiune 


b) (FETCH) 


T2 
Ciclu maşină M2 


T3 


Fig. 4.1. Cicluri mașină de bază 


nului, am rezervat un cîmp de comentarii în care indicăm adresa de locare a 
instrucţiunii în memorie (ADR), mnemonica instrucţiunii (MNE), codul ei (COD), 
precum și ciclul de tact (T) și cel de mașină (CM), curent. 


Primul ciclu mașină (M1) efectuat pe parcursul unei instrucțiuni, are un rol 
aparte. Pe parcursul lui se efectuează citirea și interpretarea codului instrucţiunii. 


Microprocesorul posedă un pin dedicat, pe care generează semnalul M1. Activarea 
acestui semnal, aduce la cunoștința lumii înconjurătoare faptul că microprocesorul 
execută cel mai important ciclu mașină. 
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Să considerăm instrucţiunea : 

LD H,73n 

Codul instrucţiunii este : 264 73u 

Semnificația ei : încarcă registrul H cu 73u. 

În primul ciclu de tact (T=1) al primului ciclu mașină (CM=1) conţinutul 
contorului program (PC) este depus „via” registrul tampon deadrese (AB) pe 
magistrala de adrese. Concomitent se activează semnalul M1. Puțin mai tîrziu 
se activează semnalele MREQ și RD, semnalînd elementelor din sistem faptul 
că se solicită un acces la memorie (MREQ — memory request) și că accesul 
este de tip citire (RD—read). Vezi lm.1. 


E._ă 
DS IE ae 
1 $ cc MG TE TRACE! Pas AA 
ADR ÎMNE:LD H,72 
7ada |COD:2673 [CM:81 | 


CBEEICBCII 


IX 7209 


MEMO 
AF 


COMMAND 1” aoeaa 
CIRCUIT SF __7E0 
Bu IFF1:0 n 
Su ip PE Paaa 
H â a :a m || 
ua ? “Di 7eee 


Im.1 


În următorul ciclu de tact (T=2) codul de instrucțiune citit de la adresa 
(PC=7000) se depune în registrul tampon de date al microprocesorului. În cazul 
de față acest cod are valoarea 264. Semnalele M1, MREQ, RD sînt în continuare 
active. Vezi Im 2. 

După ce contorul program PC a fost incrementat (PC=—7001) pentru a indica 
adresa următorului octet de citit din memorie, urmează cel de-al treilea ciclu 
de tact din primul ciclu mașină (T=—3). Prima parte a ciclului M1 s-a terminat: 
codul instrucţiunii a fost citit în interiorul procesorului. Semnalele M1, MREGQ, 
RD sînt dezactivate. Se activează în schimb semnalul RFSH, pentru a semnala 
faptul că începe activitatea de reîmprospătare a memoriilor dinamice. În acest 
scop conţinutul registrului R (în cazul nostru R=394) este depus pe liniile 
AO — A6 ale magistralei de adresă. Conţinutul registrului tampon de adresă se 
schimbă astfel din 7000 în 7039. Vezi Im. 4. 
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Concomitent cu emiterea adresei de refresh, codul instrucţiunii se depune în 
registrul de instrucțiune IR, pentru a fi interpretat. Este foarte eficientă utilizarea 
resurselor de timp în acest caz: microprocesorul desfășurînd activități interne, 
pentru decodificarea codului din IR, magistralele externe de date și adrese sînt 
libere. Ele pot fi folosite în alt scop, de exemplu pentru a se reîmprospăta o 
eventuală memorie RAM dinamică, legată în sistem, ușurînd astfel considerabil 
munca proiectantului de hardware. 

Acum se activează din nou semnalul MREQ, care poate fi folosit pentru 
generarea semnalului RAS (Row Address Strobe), semnal specific al memoriilor 
dinamice. Menţionăm că semnalul RFSH nu putea fi folosit în acest scop, deoa- 
rece în momentul activării lui (la începutul lui T=3), adresele de reîmprospă- 
tare (A0—A6) nu se puteau considera stabilizate. Astfel constructorii de hard- 
ware vor putea folosi semnalul RFSH, doar pentru a comuta regimul de lucru 
al memoriei. Starea curentă a microprocesorului o vedem în Im. 5. 

La începutul tactului T4 (T=4) conținutul registrului de reîmprospătare R, 
este incrementat, pregătindu-se adresa liniei care va fi reîmprospătată în urmă- 
torul ciclu de reîmprospătare (totdeauna în M1). Vezi Im. 6. 

Amintim faptul că în ciclul refresh; liniile superioare de adresă A8 — A15 
vor reda conținutul registrului | (1), element necunoscut la elaborarea lui Visible 
Z80, precum și faptul că cel mai semnificativ bit (D7) al. registrului R nu este 
afectat decît de semnalul RESET (care-l va șterge). 

Utilizîndu-l ca indicator, programatorul va putea să realizeze „capcane”, cel 
puţin interesante. 


63 


SPEEDȚ erp repre ee ups 
i EREI - DE i =: MC IC TRACE FAST 

ADE ÎMNE:LD H,73 
7o00 |con:2672 


0ooaog 18 
S2XHXFNC 
oooseaa ia 


a 28 


ENCZI CICI: 


E'calc'ea 


| 


id LA 

SEC] [x 7208 

COMMAND || 1% 9000 

CIRCUIT SF  7E0o 
IFF1:a 


USR 
Uz FC 72001 
ESET IFF2:Q8 
aL T 
digi MGB :8 
RE 7932 Ș: 


Im.5 


IaA00 Ex-ezz- 
30 
? 


LI] 


LG RAZE FAsT 


: 2673 


uta! 


COMMAND 
CIRCUIT 


E 
ÎN ae, £ 


L.] 
a a DL REA polari gi n Acta ecua pa 1] 
15 ce Me IE TRACE FAST 
ADR  |MNE:LD H,FE 
7eaa | con: ze7z 


IAN Sa 
EMC 20 


Ciclul mașină M1 se încheie la sfîrşitul tactului T4, cînd codul citit este 
decodificat. Vezi Im. 7. Acesta este momentul în care microprocesorul a înțe- 
les tot ce are de făcut pentru efectuarea instrucţiunii citite. (LD Hn) 

Pentru mai multă rigurozitate și pentru a veni în ajutorul celor care doresc să 
realizeze fizic un sistem cu microprocesorul Z80, redăm în fig. 4.2. diagramele 
de timp ale semnalelor interesante. 

Reţinem faptul că ciclul mașină M1 durează 4 tacți procesor. Sînt numeroase 
instrucțiuni care pot fi finalizate pe primul front crescător al semnalului de tact, 
care urmează după T4. Aceste instrucțiuni vor fi deci executate într-un singur 
ciclu mașină. (Din această clasă fac parte toate instrucțiunile de transfer între 
regiștri LD r,, ra). : 

Există însă instrucțiuni care, cu toate că nu mai necesită efectuarea nici 
unui alt acces la memorie (sau mai general spus nici o altă activitate externă 
procesorului), nu pot fi executate pe durata ultimului tact T4 al primului ciclu 
mașină. Acolo unde necesarul de timp suplimentar este de un ciclu de tact, pro- 
blema s-a rezolvat amînînd execuția ultimei secvențe pe următorul ciclu mașină, 
(ciclu care poate face parte din instrucțiunea următoare). Astfel se poate cîştiga 
durata unui ciclu de tact, care înseamnă un spor de viteză de 20% (4 tacţi în 
loc de 5), Tehnica se numește suprapunerea ciclurilor mașină (sau „furt de ciclu”). 
Asupra ei vom reveni la tratarea instrucțiunilor logice în Aventura a 4-a, acolo 
unde ea este utilizată frecvent. 

„ Pentru instrucțiunile care necesită 2 tacți suplimentari, ciclul mașină M1 se 
prelungeşte cu 2 tacți. Întrucît în literatura de specialitate nu se amintește 


5 — Totul despre microprocesorul Z 80 vol. 1 şi 2. 65 


Fig. 4.2. Ciclul mașină M1 (FETCH) 


explicit acest tip de ciclu mașină, vom fi nevoiţi să-l denumim noi. ÎI vom numi 

ciclu M1 extins. 

În fig. 4.3. redăm diagrama de timp a semnalelor procesor folosite în acest 

ciclu, 
Înstrucţiunile care lucrează cu acest gen de ciclu M1 sînt cele de incremen- 

tare și decrementare a regiștrilor dubli: INC rr și DEC rr, unde rr poate fi 

BC, DE, HL, SP, IX, IY. 


e LPF | Ra a RV AA O 
muz br: EEE E MI A 


Fig. 4.3. Ciclul M1 extins, avînd 6 cicluri de tact (ex.: INC HL) 


Amintim că execuția acelorași instrucțiuni pe microprocesorul 18080 durează 
doar 5 tacți — Tactul suplimentar T6 apare la Z80 datorită prezenţei regis- 
trilor de index IX şi |IY care folosesc resurse hardware comune cu HL. (La 
execuţia incrementării/decrementării este nevoie de un tact suplimentar pentru 
luarea unei decizii : registrul dublu va fi HL, sau unul din regiștri index IX, 
IY ?). 

Pe durata e dp de tact suplimentare T5 şi T6 semnalele de comandă ale 
procesorului sînt inactive. 


Continuăm prezentarea instrucţiunii ilustrate la fetch : LD H,73. Cel de-a: 
doilea octet din cîmpul instrucţiunii (octetul de date 734) este citit de la adresa 
7001 și depus în registrul H. 


În primul ciclu de tact (T=1) al celui de-al doilea ciclu mașină (CM=2) conți- 
nutul contorului program este depus pe magistrala de adrese. Vezi Im. 8. Pro- 


cesorul activează semnalele de comandă MREQ şi RD pentru a semnala operația 
de citire a memoriei. Octetul citit de la adresa 7001,, se depune în registrul 
tampon de date al microprocesorului. Vezi Im. 9. 

Urmează o activitate standard (ce apare în cursul fiecărui ciclu de acces la me- 


morie efectuat cu participarea lui PC) incrementarea contorului de adresă, pentru 


a indica adresa următoarei celule ce va fi accesată. (vezi Im. 10). 
Ciclul READ se termină în T3, odată cu depunerea octetului citit în regis- 


trul intern dorit, (H în cazul de faţă) (vezi Im. 11). 

Pentru a corecta micile inexactități de temporizare ale lui VISIBLE—Z80 
redăm celor interesați diagramele de timp, ale ciclului de citire al memoriei 
(READ). (vezi fig. 4.4). 

Dacă nu apar stări WAIT (vezi cap. 9.1) ciclul de citire memorie READ 
durează 3 tacţi procesor. 


Acest ciclu, durează (asemănător ciclului READ) trei tacți procesor. Cei 
interesaţi vor putea urmări execuţia unui asemenea ciclu în 1M.52—1M.54 din 
Aventura nr. Î, la ilustrarea instrucţiunii LD (HL),A, instrucțiune care transferă 
conținutul registrului A în memorie la adresa indicată de HL. 
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Fig, 4.4. Ciclul de citire din memorie (READ) 


Memorie WRITE 


Fig. 4.5. Ciclul de scriere în memorie 
(WRITE) 


Din diagramele de timp (vezi fig. 4.5) ale ciclului WRITE remarcăm apariția 
cu o întîrziere de un tact a semnalului de scriere WR, față de cererea de acces 
la memorie MREQ. Astfel datele plasate de către procesor pe magistrala de 
date, odată cu activarea semnalului MREQ, vor avea timpul necesar pentru a se 
stabiliza înainte de apariţia semnalului de înscriere. 
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Acest ciclu mașină, deși nu se prea vorbește despre el, există. Pe durata 
lui, semnalele de comandă sînt inactive. Dacă cineva își propune să vîneze un 
astfel de ciclu mașină cu sonda de osciloscop în mînă, n-are decît să introducă 
instrucțiunea 

INC (1Y + IND) 


în buclă, și să vadă ce se întîmplă cu semnalele de comandă ale microproceso- 
rului în răstimpul dintre T1 și T6. Il vom scuti de această căutare, de loc ușoară, 
recomandindu-i diagramele de timp din fig. 4.6. 

Pentru a evita orice dubii privind existența acestui ciclu analizăm repartiţia 
de tact a instrucţiunii INC (1Y4+364): 


M1 M1 M3 M4 M5 M6 


23 tacţi (4, 4,3, 5, 4,3) 
Rememorîndu-se codul acestei instrucțiuni : 


FDu 344 36 


constatăm : 

M1 (4 tacți) se citeste codul rezervat FDy care specifică implicarea regis- 
trul |Y în operația care va urma. 

M1 (4 tacţi) se ciţește cel de-al doilea cod de instrucțiune 344 (care 
înseamnă de fapt INC (HL)), pentru a se determina instruc- 
țiunea de executat. Se observă prezența celui de-al doilea 
ciclu M1 în cadrul aceieiași instrucțiuni. 

M3 (3 tacți) se citește indicele 36, pentru adresarea indexată a unui ele- 
ment din memorie. 

M4 (5 tacţi) este ciclul intern căutat în care se calculează adresa de memo- 
rie căutată, însumînd registrul IY cu indicele (364 în cazul 
de față). 
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zip, 4,6. Ciclul mașină intern ; toate semnaleie de comandă sînt inactive 
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M5 (4 tacți) se citește octetul dorit din memorie și se incrementează. 
M6 (3 tacți) Se rescrie valoarea incrementată în celula de memorie adre- 
sată prin IY + 364 


Ciclul mașină intern se poate executa și în paralel cu alte activități externe 
ale procesorului. Astfel se cîștigă timp. Demonstrăm evenimentul cu ajutorul 
instrucţiunii : 


SET 0,(1Y +36) 
cod : FDu CBu 36 C6u 


Remarcăm prezența în cîmpul instrucţiunii de 4 octeți a 3 coduri de instrucțiuni 
(FDy, CB, C6) și a unui octet de date (36|). De ce oare cel de-al treilea 
cod (C6,) nu a fost amplasat imediat după CB ? Răspunsul este: pentru a cîș- 
tiga 4 tacţi în execuţia instrucţiunii. 

După citirea indicelui (364) oricum va trebui efectuată adunarea lui la con- 
ţinutul registrului IY, operaţie care durează 5 tacți procesor. În paralel se poate 
citi cel de-al treilea cod de instrucțiune : C6y, care de fapt spune ce anume 
trebuie făcut, primele două coduri nespunînd decît generalități. 

Dacă cel de-al treilea cod de instrucțiune, (C6y) ar fi fost implementat pe 
poziţia a treia distribuția de tacţi în instrucțiune ar fi fost: 

SET 0,(1Y+4+36,) caz ipotetic : (4, 4, 4, 3, 5, 4, 3) — 27 tacţi 


M1 M1 M1 M4 M5 M6 M7 


unde : 3 x M1 ar fi fost afectate pentru citirea celor 3 coduri de instrucțiune 
M4 ar fi citit indicele (364) 
M5 ar fi calculat adresa indexată 
M6 ar fi citit din memorie octetul de modificat 
M7 ar fi reînscris în memorie octetul modificat 


În realitate avem: 
SET 0,(1YF-364) caz real: (4, 4, 3, 5, 4, 3) — 23 tacţi 
M1 M1 M3 M4 M5 M6 


unde: 2 X M1 citește primele două coduri de operație FDu și CBu 

M3 citește indicele 36, 

M4 citește cel de-al treilea octet de cod C6y (4 tacţi) și calculează 
adresa indexată (5 tacți). Durata ciclului este determinată de 
operația mai lungă. 

M5 citește din memorie octetul de modificat, 

M6 rescrie în memorie octetul modificat. 

Astfel, suprapunînd un ciclu intern peste unul extern, s-a crescut viteza de 
execuție a instrucţiunii de la 27 tacți procesor la 23 tacţi procesor. 

Existenţa ciclurilor mașină interne constituie o realitate de a cărei existență 
va trebui să ştie orice utilizator serios al microprocesorului Z80. 


Sînt :oare transferurile un scop în sine? Cunoscînd faptul că din cele 696 
de instrucțiuni ale microprocesorului Z80, 154 nu fac altceva decît mută octeții 
în interiorul procesorului şi între procesor și memorie, am fi tentaţi să credem 
că da. Acceptînd transferurile ca o expresie a mișcării, gîndurile ne îndeamnă 
la asocieri mai ample. Mișcarea este o formă de existență. O formă de exis- 
tenţă „a tot ceea ce este viu'”, însăși a materiei. Dar cum, spre deosebire de mate- 
rie, microprocesorul este un produs al omului, să nu ne grăbim cu răspunsul; 
nici dacă una din cele două funcții majore ale calculatoarelor electronice, care 
s-au cristalizat în cele 4 decenii de existență ale lor, vehicularea de date, se con- 
stituie în proporție de 90% din transferuri. Oricît de sofisticate ar fi calcula- 
toarele din zilele noastre, datorită însăși genezei lor, ele nu pot nicidecum în- 
treprinde acțiuni cu un „„raison'' mai profund decît cele pe care le permite ima- 
ginaţia oricum limitată a creatorului lor, omul. Așa stînd lucrurile, să încercăm 
să depistăm raționamentul care impune includerea în setul de instrucțiuni al 
oricărei unități centrale existente a unui subset bogat de instrucțiuni de transfer. 
Căutările noastre nu trebuie să fie îndelungate. 

Reamintindu-se doar faptul că operaţiile aritmetice și logice se desfășoară 
totdeauna cu implicarea unui operand dintr-un registru special, numit acumulator, 
ne situăm deja în miezul problemei. Pentru a putea fi prelucrate datele trebuiesc 
aduse (transferate) în acumulator și în regiștri interni. lată de ce funcționarea 
microprocesorului Z80 este de neimaginat fără instrucțiuni de transfer. 

Cererea de asemenea instrucțiuni este amplificată și de numărul limitat al unor 
alte elemente privilegiate : regiștri interni. Foarte frecvent capacitatea lor de sto- 
care se dovedește astfel insuficientă, chiar și pentru rezolvarea unei probleme 
mărunte. În acest caz vom fi nevoiţi să apelăm din nou instrucţiunile de transfer. 
Dacă nici memoria internă nu se dovedește a fi suficientă, eliminăm o parte 
din date din calculator, urmînd să le rechemăm altă dată, la nevoie. Dar aceste 
transferuri sînt de altă natură : ele sînt de intrare/ieșire și fac legătura cu lumea 
externă, vie. Rămînînd la transferurile interne, amintim că pentru efectuarea lor 
cît mai eficientă s-au pus la punct numeroase „„mecanisme”', începînd cu diver- 
sele tehnici de adresare și culminînd în memorie cash și în cea virtuală. Adică 
tot ce a realizat tehnica de calcul mai frumos și mai bun. Punîndu-se întrebarea 
dacă instrucţiunile de transfer ar putea fi totuși eliminate, răspunsul îl obținem 
reconsiderînd cauzele care au dus la apariția lor: inegalitatea elementelor com- 
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ponente. Dacă s-ar putea realiza o structură în care toți membri să fie egali, 
dotați cu aceleași resurse, ar fi posibil. Dar așa cum o demonstrează istoria, ar 
fi cel puțin păcat. Un model astfel realizat ar rămîne unul utopic. Atiît. 

Acceptînd ideea că instrucțiunile de transfer reprezintă un rău necesar, să 
vedem ce ne oferă ele. 

În funcție de cantitatea informațională pe care o vehiculează distingem 3 
clase de instrucțiuni de transfer: 

— instrucţiuni de transfer de 8 bit — vehiculează 1 octet 

— instrucțiuni de transfer de 16 bit — vehiculează 2 octeți 

— instrucțiuni de transfer de blocuri de date — vehiculează 1 — 65536 

octeți, 

Ca acțiune generală notăm că în majoritatea lor copleșitoare, instrucțiunile 
de transfer acționează unidirecțional : informaţia se preia dintr-un loc denumit 
sursă și se depune în alt loc numit destinație. Combinaţiile sursă-destinaţie pot fi : 

— registru intern — registru intern, 

— registru intern — memorie 

— memorie — registru intern 

— memorie — memorie 

Acest din urmă tip de transfer apare la instrucțiunile care vehiculează blo- 
curi de date, transferîndu-le dintr-o zonă de memorie în alta. 

Cu puţine excepții mnemonica instrucţiunilor de transfer este 


LD (load-încarcă) 
Forma generală a instrucţiunii scrisă în limbaj de asamblare este 
LD destinaţie, sursă 


Există însă și instrucțiuni care declanșează transferuri bidirecţionale. În acest 
caz este impropriu a vorbi de sursă și destinație, întrucît ambele elemente impli- 
cate în transfer sînt atît surse cît și destinaţii, conținutul lor interschimbîndu-se. 

Aceste instrucțiuni au mnernonica generică EX, forma lor, scrisă în limbaj 
de asamblare fiind : 


EX elementi, element? 


Toate instrucțiunile de acest gen operează pe grupe de 2 octeți (16 bit), 
totalul lor cifrindu-se la 6. 

Tot în clasa instrucţiunilor de transfer pe 16 bit găsim și cele notate cu 
PUSH respectiv POP. Prin natura transferului efectuat, ele vor putea fi consi- 
derate ca etalon de load (transfer) indirect între regiștri dubli și memorie. Prin 
alocarea acestor mnemonici, diferite de LD, elaboratorii microprocesorului evi- 
denţiază folosirea unui registru de adresă special (indicatorul de stivă SP) şi o 
o tehnică (detaliu) specială. 

Numărul total al acestor instrucțiuni este de 12. 

Instrucţiunile de transfer a blocurilor de date, ultimele a căror mnemonici 

viferă de LD au fost mai fidele : ele păstrează în numele lor — LDD, LDI, LDDR, 
LDIR — cele două litere care le- trădează apartenența. 

În rest instrucțiunile de transfer sînt destul de pașnice. Viaţa lor este o 
carte deschisă (totul se înțelege din enunţul instrucţiunii) ele neafectînd nici un 
indicator de condiţie (flag), 

Și totuși pentru ca regula să fie confirmată există și aici 4 excepţii, instruc- 
lunile LD A; LD A,R; EX AF, AF'; POP AF. 


7A INSTRUCȚIUNI DE TRANSFER 


un 


1. Aventura 1: transferuri de 8 bit 


Să recurgem acum la VISIBLE—Z80 pentru a întreprinde o incursiune în lumea 
instrucțiunilor care transferă cîte un octet. O aventură pe parcursul căreia vom 
încerca să dezlegăm toate tainele, oricît de ascunse, ale acestei clase de instrucțiuni. 


LD 44,73 


L. LA A i 7 


LD BA 


LD D,(1X+4+06) m23 —1m49 (Cf 


D (HL),75 Im50—lm54 (hi 


Șirul de instrucțiuni de mai sus este doar o secvenţă. Ea nu poate fi numită 
program, datorită faptului că nu are funcționalitate în sine. (Dacă nu cumva 
atașăm această noțiune fenomenului că spre deosebire de momentul lansării cînd 
doar contorul program (PC=7400) diferă de zero, la sfîrșit conținutul regiștrilor 
dubli se aliniază și el: HL=—7300; DE=—7200; BC=—7100. Dar asta este artă 
pentru artă.). 

În coloana din stînga avem adresele de început, în coloana a 2-a enunţul 
instrucțiunilor în limbaj de asamblare, iar în cea de a 3-a, care reprezintă comen- 
tarii, numărul imaginilor generate de VISIBLE—Z80 pe care prezentăm instruc- 
iunea cu pricina. Specificația din paranteză CC, sau MC semnalează modul de 
lucru al simulatorului VISIBLE—Z80. 

CC — clock cycle — regimul cel mai detailat, tact cu tact. 

MC — machine cycle — regimul în care se face o singură vizualizare la 

sfîrșitul fiecărui ciclu mașină. 
Toate numerele sînt hexazecimale. 

Instrucţiunea LD H,73 care este o instrucțiune de încărcare imediată a unui 
registru intern, am prezentat-o (Im.1—lm.11) în cap. 4. Rememorîndu-se ultima 
imagine !m.11 observăm că data (734) este „aruncată” peste registrele B,C,D,E 
în H. Fenomenul este înșelător, căci în realitate magistrala internă de date ajunge 
la fiecare registru. Din motive de lipsă de spațiu, în VISIBLE—Z80 nu a fost 
reprezentat racordul fiecărui registru în parte la magistrala internă de date, ci 
doar pentru întregul bloc de regiștri. 


Remarca 1: Dacă în cursul execuţiei unei instrucţiuni, fie ea de transfer sau nu, 
oricare din regiștri de uz general este implicat, selectarea lui se va face printr-un multiplexor 
(de asemenea nereprezentat de VISIBLE—Z80), pe baza unei adrese codificate pe 3 bit, 
preluată din însuși codul instrucţiunii. Adresele regiștrilor interni sînt : 


ro Fr ro reg. 


=>3>2>0000 
==00300 
-0>0>0>0 
> rIm0DO» 


URA II 75 


În cazul instrucțiunilor de încărcare imediată a regiștrilor simpli formatul octetului 
de cod este: 


00r,r,r 110 
Biţii b-(=0), bs(=0), b2(=1), b1(=1), bo(=0) definesc grupa de instrucțiuni, iar bs (=r2), 
ba(=r) și ba(=ro) specifică registrul dorit. 
Pentru registrul H (100) rezultă codul 00100110 (26,,), adică cel pe care-l cunoaștem 


din imaginile prezentate. Deducem cu ușurință codul următoarei instrucțiuni din listă: 
LD A,71, care face parte din aceeași grupă cu cea precedentă. Registrul A are adresa: 111, 
Codul instrucţiunii de încărcare imediată va fi deci 00111110 adică 3E,,. 


Execuția instrucţiunii fiind similară cu cea precedentă, folosim prilejul de 
a-l familiariza pe cititor cu imaginile generate de VISIBLE—Z80 în modul MC 
(ciclu mașină). 


SPE EDER RP EEE 
1" solce Tue e TRAGE Fasrillil 
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riza 


Im. 12 


Indicatorul de viteză (și mod de lucru) al simulatorului este poziționat pe MC. 
La sfîrșitul primului cic!:: mașină, cel de citire al codului de instrucțiune din 
memorie (CM=1 ; T=4) se indică, vizualizîndu-le în video invers, toate elemen- 
tele afectate de acel ciclu. 


Remarca 2 : în ciclul mașină M1 (FETCH) elementele afectate par a fi mereu aceleași, 
indiferent de instrucțiunea executată : contorul program (PC), bufferul de adrese (AB), 
magistrala de adrese (A0—A15), memoria, magistrala de date (D0—D7), bufferul de date 
(DB), registrul instrucțiune (IR), registrul refresh (R) şi circuitul de comandă, în frunte 
cu decodificatorul său. Elementele menţionate se activează într-adevăr de fiecare dată, Instruc= 
ţiunile care se execută într-un singur ciclu maşină, au și elemente suplimentare, așa cum 
vom vedea pe parcurs, 


76 


SERROL LR e Pa e 133] 
1 CE MC LE = RECE FAST 


[5R [ce_7 Fă 
L-M: zi | 


Faaz | COD:3E71 EI] 


ai aa 
il nai 
75-a] 
CACI ECE e 
EREI 
noa c- ee | LE 
pară 


iNT 
tIM [R ze]! aa] 
o a 
Pui d IX 7408 
FE COMMAND 1Y aaa 
!R (SF __7EaQ._| 
euzea CIRCUIT ZF __7Eaa 
E ați  7ae 
REZET i SERE Dle 
HALT 
FF ah 3 
Mi 1 T a 


Im. 13 


Instrucţiunea LD A,71 se termină cu cel de-al doilea ciclu mașină, un ciclu 
READ (CM=2; T=3). În Im.13 se vede cum octetul citit de la adresa 7003 
(714) se depune în registrul A. 

Aţi remarcat desigur faptul că în modul de lucru ciclu mașină (MC) sem- 
nalele de comandă nu se mai activează. Am renunţat la ele pentru a nu îngreuna 
inteligibilitatea imaginii. Între timp contorul program indică deja adresa instruc- 
țiunii urnszătoare : 


Instrucţiunea de față este o instrucțiune de transfer între regiştri, Ea se 
codifică pe un singur octet: 47p. 
Spre deosebire de cele două instrucțiuni prezentate mai sus, în cazul transferu- 
rilor între regiștri, atît elementul destinație cît și cel sursă se specifică implicit, 
prin codul binar al instrucţiunii. Structura lor este: ; 


01 d, d, do S2 S+; So 


Primii doi bit — b„(=0), be(=—1) semnalează faptul că avem de-a face cu o 
instrucțiune de transfer între regiștri. Pe biții mai puţin semnificativi by — bo 
apare adresa registrului destinație b; — b; și apoi cea a registrului sursă b> — bo 


Remarca 3 : Mulţi au întrebat de ce a ales firma Intel forma generică a instrucţiunii 
sale ca fiind: 


MOV Try, ro 
De ce nu se specifică prima dată sursa și apoi destinaţia ? 


Atiît citirea în limba engleză cît şi în limba română ne sugerează: "Move r, tora”, „mută 
P4 în r2” și nici decum „Move ro to rj”, „„mută ro în r.” aşa cum se întîmplă de fapt. 
„„Păcatul” se trage din structura codului instrucţiunii de transfer între regiștri, în care codul 
registrului destinație apare în stînga celui al registrului sursă. Așa să fie și în limbajul de 
asamblare, şi-au spus cei de la Intel, avînd totodată nefericita inspirație de a denumi acțiu- 
nea move (mută). Cei de la Zilog au eliminat neconcordanța schimbînd mnemonica: LD. 
Load (încarcă) inversează și sensul acțiunii : astfel LD B,A, „„load B with A” („încarcă B-cu 
A) sună bine și este corect. 


Dar să nu ne lăsăm pradă poveștilor cinegetice, căci timpul trece și VISIBLE 
— Z80 lucrează : 


ENIAND Em-zz2-— 
PHEMCC DO0Ga-22Z 


Im.14 


LD r,,r, fiind instrucțiuni cu un singur ciclu mașină în starea CM=1, T=4 
LD B,A s-a și terminat, și așa cum vedem în Im.14 registrul B conține deja ace- 
eași valoare ca și A, nu 00 cum fusese înainte. 


Remarca 4: La toate instrucțiunile de transfer unidirecțional, conținutul elementului 
sursă (registru sau celulă de memorie) rămîne neschimbat. Conţinutul iniţial al elementului 
destinaţie (registru sau celulă de memorie) se pierde, peste el înscriindu-se conținutul sursei 


„Deși un transfer între doi regiștri interni ai microprocesorului, — această 

instrucțiune permite înscrierea vectorului de întrerupere în registrul dedicat | —, 

necesarul ei de timp și memorie este de cel puţin două ori mai mare decit cel 

al transferurilor între regiștri de uz general. 

In momentul (CM=1, T=4) se termină primul ciclu mașină, odată cu decodifi- 

nt codului ED, care este un cod rezervat. Urmează citirea codului, propriu-zis : 
H: 
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79 


Observăm că și în acest al doilea ciclu mașină s-au semnalat elementele spe- 
cifice pentru ciclul M1 : IR, R, și circuitul de comandă. 


Remarca 5 : Dacă o instrucțiune încorporează 2 sau 3 octeți de cod, atunci la citirea 

fiecăruia se va efectua un ciclu mașină M1 (FETCH) cu toate detaliile, incluzînd reîmpros- 
pătarea memoriilor dinamice și incrementarea registrului R. (Am putea afirma că circuitele 
de memorie RAM dinamic sînt încîntate de prezența instrucțiunilor multicod, căci executarea 
lor mărește frecvența de repetiţie a ciclurilor refresh). 
In lm.16 observăm că cel de-al doilea ciclu FETCH a durat, spre deosebire de cele întîinite 
pînă acum 5 cicluri de tact. Explicația fenomenului constă în faptul că registrul | fiind, ca 
şi R de altfel, un registru special, a cărui abordare diferă de cea a regiştrilor de uz general, 
acesta necesită un tact în plus. Același fenomen îl ir ar şi la is înei dpl inverse, de citire, 
a registrilor hardware | şi R. (LD A,lşi LDA,R). 


Prezența parantezelor în jurul celui de-al doilea operand este un semn că A 
nu va fi încărcat cu registrul dublu BC (ar fi şi greu, nu-i așa, să înghesui 16 bit 
în 8 bit 2), ci conținutul acestui registru este folosit ca adresă de memorie. Con- 
ținutul celulei astfel găsite se transferă în registrul A. Ex. de față este un caz 
clasic de adresare indirectă prin registru dublu. 


urale e: 
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1lm.17 


La sfîrşitul primului ciclu mașină (lm.17), codul OA, unicul byte al instrucţiunii, 
este interpretat. Urmează inserarea unui nou ciclu mașină pentru efectuarea trans- 
ferului propriu-zis. 
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Ilm.18 


De la adresa 7100, s-a citit valoarea 724 care s-a depus în A. (Aici începe pele- 
rinajul octetului 72, care, după lungi peripeții, va ajunge în finalul aventurii în 
registrul D). 


Remarca 6 : Încărcarea și salvarea indirectă a acumulatorului este posibilă folosind 
oricare din cei trei regiștri dubli BC, DE, şi HL. Ceilalți regiștri (B, C,D,E,H,L) nu pot 
fi implicați în instrucțiuni de transfer indirect, folosind regiștri BC și DE, ci doar registrul 
HL. Reţinem deci că atît A, cît și HL sînt privilegiați față de colegii lor de breaslă B, C, 
D,E,H,L respectiv BC și DE. 

(ex, : instrucțiunea LD B, (DE) nu există). 


Încărcăm celula de memorie avînd adresa 7406, cu „valoarea curentă a acumula- 
torului (724 — cel .amintit). . 
Instrucţiunea este un exemplu de adresare directă: în cîmpul instrucţiunii se 
specifică în mod explicit adresa la care se va efectua transferul. 

După citirea și decodificarea octetului de cod 32, (lm.19), circuitul de comandă 
al microprocesorului trece la citirea adresei căutate 7495,, care se află specificată 
în octeții imediat următori codului de instrucțiune. 

Cel de-al doilea ciclu mașină (ciclu READ în cazul nostru) se termină cu încăr- 
carea octetului 06, în registrul intermediar și transparent Z. 


Remarca 7 : În mod absolut consecvent, microprocesorul Z80 salvează regiștri dubli 
astfel încît octetul mai puţin semnificativ (conţinutul regiștrilor C, E, L) se înscrie la adresa 
nominalizată, iar octetul cel mai semnificativ (registrul B, D, H) se depune la adresa imediat 
superioară. La citirea unui cuvînt (16 bit) din două locaţii succesive de memorie, conţinutul 
adresei inferioare se consideră octetul cel mai puțin semnificativ, transferîndu-se ca atare 


g7Ţ Totul despre microprocesorul Z 80 vol. 1 și 2. 81 


82 


Ze EcoPEEE Pere peeeterereee ia 
4 3” al a MC IC FACE FAST 


e2eoea 19 
2335525 
2020818 


za: 


a02a 


FE2D 
Pana 


1 


CHIN €Am-—-zz2— 
ENEMCC A00H-2Z 


Im. 19 
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în jumătatea cea mai puţin semnificativă a regiștrilor dubli. De aceea în imaginea de memorie 
a unui program cuvintele de 16 bit apar cu octeți inversaţi. În cazul nostru mnemonicii 
LD (7406),A îi corespunde codul 


324, 06, 744 
În ciclul mașină M3 (lm.21) se citește partea cea mai semnificativă a adresei, 
74,4, și se depune în-registrul transparent W. 
Avînd adresa de memorie formată în registrul dublu WZ, poate începe ciclul 
mașină M4: A se transferă .în memorie la adresa 74064. M4 (vezi lm.22) este 


un ciclu de scriere în memorie (WRITE), pe parcursul căruia la adresa specificată 
de AB (7406,) se transferă octetul 72. 


Remarca 8 : În condiţii normale, durata ciclului WRITE este, ca și cea a ciclului READ, 
3 tacți procesor. 


Această instrucțiune încarcă registrul D din memorie. folosind tehnica de adresare 
indexată. Cunoscînd conținutul curent al registrului index IX, adresa celulei de 
memorie căutate va fi 7400, + 06, = 7406, (Aceeași la care am înscris cu instruc- 
țiunea precedentă. Periplul numărului 72, continuă deci). 

Codul binar al instrucţiunii este : DD,456,06,. Se execută 19 tacţi procesor repar- 
tizați pe 5 cicluri mașină 19 = 4+4-+-3+5+3. 

V-am pregătit o surpriză. Privind lm.23 observați că am redus viteza de simulare 
(SPEED) a instrucţiunii la minim, și folosim modul cel mai detailat al lui VISI- 
BLE— Z80. Faceţi-vă deci comozi, fiindcă urmează o instrucțiune derulată pe 27 
imagini ! 

Începe primul ciclu FETCH : se citește codul DDy 


spegoPerrprrre parere 
15 cc MC. RACE Pas Si 


ADR 
7O00E 
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Codul citit de la adresa 700By se depune în bufferul de date al microprocesorului 


_. 
ZFEED 
A E tz = MC ic RACE FatT SĂ 


ADR ÎMNE:LD Dc IX+05H) 
FABE | COD: DDEEoE cM:a1 ? 


CRET) EREI 


— 
Viza 
AP COMM iY D808 

Î CIRZUILT SF 7Eae 
BIUZRA 
ELIZ Ak, FC 709908 
FEZET n ; 
mai T > 
RF + ă i 
MI PE 790E 


Im. 24 


Se incrementează contorul program : PC=PC-+1=700Cy4 


mile aa cc MC. LE =i TROCE FâsT 
ADR |MNE:LD D.(1X+98H) DE DOP 
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Conţinutul registrului R se depune pe magistrala de adrese AO — A6 și incepe 
ciclul de reîmprospătare a memoriei dinamice (RFSH-—activ). 


Ei A 
ZFEEDFE Sau 
SREEDN EPOPEE TELE Far 


ADR |MME:LD D.cIX+aEH) 
7ooe [eco orssae ________|en.ai| 


lw 7] 


INT 

MI 

Mi 

MFEQ 

LORG 

d COMMAND 

su CIRCUIT sr eee | 7Eoa 
e Pc _zeac | 700 
HA 195 


Concomitent codul citit DD, se depune în registrul instrucțiune, pentru deco- 
dificare. 
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Se incrementează numărătorul de refresh : R=R+1=41. 
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Acum (CM=1, T=4) codul DD, este decodificat și interpretat. Procesorul „a 
înțeles” faptul că urmează o instrucțiune în care este implicat registrul index 
IX. Pentru a ști exact ce are de făcut, a cunoaşte instrucțiunea propriu-zisă, 
microprocesorul va trebui să mai citească un cod de instrucţiune. 
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Im. 29 
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Începe deci cel de-al doilea ciclu FETCH : se citește codul nr. 2 
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Adresa codului nr. 2 ajunge la memorie, de unde se citeşte valoarea 56. 
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Im. 32 
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După stocarea codului nr. 2 (56, — DB) se incrementează contorul program 
PC=PC+1=700Dj. 
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Se demarează cel de-al doilea ciclu refresh plasînd conţinutul Tui R pe magistrala 
de adrese (A0— A6) şi activînd semnalul RFSH. 
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Codul citit se depune în IR pentru a fi analizat. 
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În timp ce codul este decodificat se incrementează numărătorul de refresh: 
R = R+1 = 424, 
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Abia acum.(CM=—2,T=—4) microprocesorul a înțeles sensul instrucţiunii primite : 
trebuie încărcat registrul D cu conținutul unei celule de memorie. 
Trebuie citit indicele variabilei căutate (deplasamentul față de valoarea curentă 


a registrului 1X). 
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Începe un ciclu de citire a memoriei (READ). PC se depune pe magistrala de 
adrese. 
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Octetul citit (deplasamentul) se depune în bufferul de date DB, 
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Se incrementează din nou contorul program PC=PC+1=700Eu4. 
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Deplasamentul citit (064) se depune în registrul tampon T. 

[ză 

SR EGO CEPE PIE RACE! Fag Dl 

ADR |MNE:LD D.(IXx+98H) 

7aee 

CO DEI TRE a e DANIE E VERO) 

WU L 
Cazi EFTITERE 
ZXHXPNC 
02018 
A: 
—————— Im.4] 


SF 7E00 


Pentru a calcula adresa efectivă, microprocesorul inițiază un ciclu mașină intern, 
pe parcursul căruia toate semnalele externe vor fi inactive. Atenţie deci: vom 
vedea acum un ciclu mașină pe care nici osciloscopul, nici analizorul de stări 
logice nu ni-l poate dezveli. Acesta este privilegiul lui VISIBLE—Z80. 


Octetul cel mai puțin semnificativ al registrului index IX este depus în cel de-al 
doilea registru tampon la intrarea unităţii aritmetice și logice ALU. 
93 


Cei doi octeți sînt predaţi unității aritmetice și logice. 


Rezultatul 
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SPEEOREErPET repere ere 
e ep -a MC TE TRaCE! Pas All 


ADR |[MNE:LD D,c(IXx+96H) 
7008 : 


COD :005s2s CM:24 


] 
N 

M 

MREG 

PT: COMMAND 

SR CIRCULT 

EUSR IFF1:0 
size Ira: 
HAL T ; 
RFSH MOD :a 
WAIT 


adunării se depune în registrul tampon Z. 


SPEEDPEEr PETE PPE EEE ET 
13 cc MC IC TRACE Pas AU 


H'eelL'oe 


=3 


27 


CIRCUIT 


AA 


SNIA00 EA-z32Z- 
DPNEMCE d00A-2Z 


Im.42 


Octetul ce | mai semnificativ al registrului X se transportă către ALU, 
sPEgDF anus 


cc ME IC TRACE FAST 
ADR 
7o0e 


MNE:LD D.(1X+95H) DE esp 
PE eee 


COD :DD5Ecoe 


lea 


COMMAND 
CIRCUIT 


spre a fi însumat cu un eventual transfer -(Cy) generat la adunarea precedentă 


SFEE. Ag: pal1Ț] 
12 cc ME IC TRACE FAST 
ADR ÎMHE:LD D.(1X+96H) DE oePy 
708E£ |CoD:D0560e [] 

eo 


D 09|E ae 
H 732|L 99 
E'0a|c'aa 
D'oa|E'08 
H'09|L'e2 
MW 74 


Im.45 


z 
9 
n 2 

LD) 


1.71 
1X 7*08 
|Y 0009 
SF 7Eo0a 
FC  700E 


COMMAND 
CIRCUIT 


E ADOX—-Z2Z 


Mr inini 
AIANLA 


Axa 


ENIAND EA-23Z2- 


PREmE 


RE 7A00 
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ce MC IC TRACE FAST 


ADR |MNE:LD D.c(IX+86H) 
7eos [eco :ooseze_______ en: 


9999992 
SZXHXPNE 
00099812 


ss-zefz 


COMMAND 
CIRCUIT 


gUs 
BUS 
RES 
HAL: 
RA? MAR a 
Rezultatul obținut se depune în registru | tampon W. 
L_ 
SN EEDI COP PE TROCE Par A 


ADR  [MNE:LD D,(1X+096H) 
7ooe |coo:Bossae______|em:e5| 


H 


73|. ee 


INTȚ 
m 
MREQ 
LOR 
i COMMAND 

CIRCUIT SF 7E00 
EUSRA 
Suza PC _700E 
RESET IŢI 
HALT iat, 
RFSH esp agr 
WuAlT E ?P2A8 


Im. 47 


Astfel ciclul mașină intern, menit să efectueze suma IX-+IND (7400+-06) s-a 
terminat. Observăm că în mare grabă VISIBLE—Z80 a înghiţit un ciclu de tact, 
efectuînd adunarea în numai 4 tacţi, în loc de cei 5 în care se întîmplă în rea- 
litate. Propunem să iertați această inexactitate, de vină nefiind VISIBLE—Z80, 


ci autorii săi. 


Începem ultimul ciclu mașină (READ) pentru a încărca registrul D. Adresa 


calculată se depune din WZ pe magistrala de adrese. 
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Octetul citit 724 (iată-l 1) se depune în bufferul de date 


cui Sat aia ate a e a 
15 cc MC IC TRACE Pas Ai 


ADR |MNE:LD D.(1X+08H) 
7aag |CoD:0D5606 |ecm:05| 


IX 7408. 
1* * aaa 


COMMAND 
CIRCUIT 


SALA 
PNEmCC 


şi apoi în registrul de destinație: D. 


Ed 
SFEEDPECrPrUCr POET Tg: pai] 
*1 5 cc MC IC TRACE FAST 
popă D,(IX+86H) 
7aae F. 


A) 


[ecs:Bossae_______enes] ţi 


7 Aumee 


COMMAND 
CIRCUIT 


LY D028 
SF 7FE08 
FC 700E 


WE 7<0E 


7 — Totul despre microprocesorul Z 80 vol. | și 2 
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Astfel ia sfîrșit cea mai lungă excursie din această carte, organizată cu 
VISIBLE—Z80 în lumea internă a microprocesorului Z80. Reţinem: 


Remarca LE Însumarea deplasamentului de un octet cu conţinutul regiștrilor index 
IX sau |Y, necesită un ciclu mașină intern avind durata de 5 tacţi procesor. Acolo unde acest 
lucru este posibil (instrucţiunile cu 3 octeți de cod) ciclului intern îi este suprapus un ciclu 


fetch, citirea celui de-al treilea cod, cîștigîndu-se astfel timp în execuția unor instrucțiuni 
indexate. 


ci În BFE MC Pe TRRCEI Fer A 


3 
ADR |MNE | 
stsdedz4 | COD : este | mt RSR 


ERZICICII 


Pentru a ne achita de o datorie mai veche, prezentarea detailată a ciclului mașină 
de scriere în memorie (WRITE), vom efectua această instrucțiune care combină 
adresarea indirectă pentru determinarea destinaţiei, cu adresarea imediată pentru 
identificarea sursei. Efectul: în celula de memorie adresată prin registrul dublu 
HL se înscrie valoarea 75. Primele două cicluri mașină le prezentăm în modul MC. 
Data de înscris se depune temporar într-un registru tampon al microprocesorului. 

MC=1 : se citește codul instrucţiunii (Im. 50) 

MC=2 : se citește data de vehiculat (Im. 51) 

Data citită în cel de-al doilea ciclu mașină — cea care urmează să fie înscrisă 
în memorie la adresa (HL) — se depune temporar într-un registru tampon al 
microprocesorului (vezi Im. 51). 
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E e i 
PO0E: |COD: 3E78 


lm.51 


COMMAND 
CIRCUIT 


Ea 22 


EATAND 


Urmează așa cum am promis, ciclul WRITE în modul CC (clock cycle). Adresa 
la care urmează a se înscrie se depune pe magistrala de adrese. (Im. 52) 
ză 
FEEOI PTT 
SH Ego Cere IE TRACE FAST 


Im. 52 
CREZI EC 

COMMAND 

CIRCUIT 


T 


PNENCE 2004-32 
A —-A 
22 
A32 


—WAT iai 


ENIIDD EA-za2Z-— 
ATANLA 


Se activează semnalul de cerere de acces la memorie MREQ. 
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Apoi octetul de înscris în memorie se depune pe magistrala de date: 


[. 
ZFEEDI ui 
1.3. CE MC IC TRACE FAST 


a 
ese|Eree|'1»” 


1NT 

MHI 

M1 

u ui COMMAND! 
EUSFA CIRCUIT SF 7E909 
BLIZAR FC 7018 
FESET - 

HÂL U 

dat [257338] 


Im.53 
În ultimul ciclu de tact (T=3) se activează semnalul de înscriere WR (WRITE), 
şi conţinutul liniilor de date, stabilizate între timp, se înscrie în memorie. 


_i 
SPEEO pt TT] 
139 cc ME IC TRACE FAST 


ADR ÎMNE:LD (HL).78 
7O0E |COD: 2675 |em:a3| 


RD COMMAND 1% ooaa 

Suca] CIRCUIT 
apei sr Eaa 
Ezza; 

RAY 

RFSH : 
WATT > 
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lată deci o instrucțiune care se descrie pe 2 octeți și se execută în trei cic- 
luri mașină. 

Amintim faptul că ciclul de scriere în memorie durează fără stări WAIT, 
3 cicluri de tact. În cazul utilizării unor circuite de memorie mai lente, electro- 
nica lor de comandă va trebui să ativeze semnalul WAIT, prin care i se cere 
procesorului să mai aștepte, căci ciclul de memorie nu s-a terminat pînă în acest 
moment. 


În acest din urmă caz microprocesorul va insera un ciclu de tact suplimentar, 
urmînd ca la jumătatea lui, să examineze din nou linia WAIT. În cazul în care 
aceasta indică în continuare cerere de așteptare, microprocesorul va insera un nou 
ciclu de tact de așteptare. 

Astfel numărul de cicluri de tact aferenţi unui ciclu de -memorie (fetch, 
read, write) sau a unui ciclu de intrare/ieșire (in/out) este variabil. În exemplele 
noastre prezentate pînă în acest punct al cărții de față, am considerat toate ciclu- 
rile ca fiind executate fără cicluri (stări) WAIT. 


Am rulat deci toate secvențele la viteza maximă, exploatînd astfel în tota- 
litate posibilitățile fizice ale microprocesorului. Către sfîrșitul primei părți vom 
detaila comportamentul microprocesorului, în cazul utilizării semnalului WAIT. 

Am ajuns astfel la sfîrșitul primei noastre aventuri, călătorie pe parcursul 
căreia am avut deja prilejul de a vede majoritatea blocurilor funcționale ale mode- 
lului de microprocesor generat de către VISIBLE — Z80, în acțiune. 

De altfel toată această pagină este o varză. 

Cele neutilizate în cadrul clasei LOAD —8, vor fi utilizate în aventurile menite 
să-l „inițieze pe cititor în tainele celorlalte clase de instrucțiuni. 

Încheiem în acest punct, nu înainte de a vă aminti faptul că modelul grafic 
de structură internă, generat de către VISIBLE—Z80, este unul teoretic și restrîns, 
el neputînd cuprinde într-o imagine de 256*256 puncte toate detaliile funcționale 
ale unui microprocesor real. 


Desprindem o ultimă remarcă: 


Remarca 10: întrucît incrementarea contorului program PC se face fără implicarea 
ALU și are loc într-un singur tact procesor, rezultă că în interiorul microprocesorului trebuie 
să existe un modul funcțional care realizează această operaţie. În modelul grafic realizat cu 
VISIBLE —Z80 dispozitivul de incrementare / decrementare n-a fost figurat, din lipsă de spațiu, 
dar el există și afectează toți regiștri. 


Pentru a fixa mai bine concluziile primei aventuri şi pentru a lămuri even- 
tualele nelămuriri ale cititorului, sintetizăm, mai riguros, tipurile de instrucțiuni 
de transfer pe 8 bit. 


Cele 111 instrucțiuni de transfer pe 8 bit ale microprocesorului Z80 posedă 
aceeași mnemonică : LD. 

Din punct de vedere funcțional le-am împărțit în 11 grupe. Cu excepția 
instrucțiunilor LD A, | și LD A,R, instrucțiunile de transfer pe 8 bit nu afectează 
indicatorii de condiţie. 

Instrucţiunile de citire a regiștrilor hardware LD A,l și LD A,R pozițio- 
nează flagurile de semn și zero, copiind totodată conţinutul bistabilului de între- 
rupere IFF, în indicatorul P/V. 

Filele grupelor de instrucțiuni din clasa LOAD—8 se regăsesc în partea a l-a 
COMPLEMENTE, $ E.2. 


„Lăsaţi la vatră”, să începem o nouă aventură, tot de la adresa 7000, adresă 
pe care v-o sugerăm și d-voastră ca adresă de început pentru programele (nu 
mai mari de 4k) care doriți să le executați cu VISIBLE— Z80. ltinerariul propus 
este : 


Secvența, deși scurtă, atinge toate cele patru mnemonici ale clasei: LD, 
EX, POP, PUSH. Totodată vom putea trece în revistă și tehnicile de adresare: 
imediată, implicită și indirectă, folosind atît transferurile interregiștri cît și cele 
între regiștri dubli și cîte două locații de memorie adiacente. 
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Pentru ca secvența de sus să nu se execute chiar fără un sens intrinsec, 
vom începe din nou cu regiștri șterși (conținut 00H), urmînd ca la sfîrșitul 
aventurii majoritatea lor să conțină aceeași valoare : 7654. 


Viteza de execuţie va fi mai mare (IC — mod ciclu instrucțiune). Astfel 
atenția noastră se va redistribui: de la „,cum” se poate face la „ce”' se poate 
face. 


Instrucţiunea execută încărcarea imediată a registrului dublu IX cu valoa- 
rea 7654. 


Instrucţiunea ocupă patru octeți în memorie : DD421454476u. 
Execuția durează 14 cicluri de tact repartizate pe 4 cicluri mașină: 4, 4, 3, 3. 
Primul popas (Im. 55) îl facem la sfîrșitul acestei instrucțiuni. 


seri a CE MC Lu ai TR ACE FAzT , ia 


ADR |IAMEE : 20 e Zic =: IRI 
dee) | CCD: : habe Beal = AR 


Şi COMMAND 
CIRCUIT 

EUSRG 

BUSAK 

RESET 

HBL.T 

RF SH 

WI T 


Im.55 


Remarca 11 : Toţi regiştri dubli pot fi implicaţi în instrucțiunile de transfer cu adre- 
sare imediată, aceste instrucţiuni dovedindu-se a fi foarte democratice. 
Observăm că ultimii 3 octeți ai instrucţiunii prezentate (21 H54476y), reprezintă de fapt instruc- 
țiunea : LD HL,7654 adică o instrucțiune cu efect similar celei precedente, schimbîndu-se 
doar registrul de destinaţie al transferului (din IX în HL). Observaţia permite formularea 
unei reguli generale. 


Remarca 12 : Din punct de vedere constructiv regiştri dubli de index IX și IY sînt 
asociaţi registrului dublu de uz general HL. 
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instrucțiunile ce operează cu regiștri de index vor avea cîte un cod rezervat (DD, sau 
FD,,) pentru identificarea registrului index (IX sau 1Y), urmat de un cod efectiv (cel care 


specifică de fapt instrucțiunea) identic cu codul instrucţiunii care efectuează o operaţie simi- 
lară, dar cu registrul HL. Datorită faptului că registrul dublu HL este oarecum privilegiat 
față de ceilalți doi (BC și DE) — avind mai multe posibilități de adresare — și regiștri index 
IX, IY se vor scălda în lumina fratelui lor mai mare- HL. 


Așa cum se va vedea pe următorul traseu al aventurii noastre : 


Instrucţiunea încarcă registrul indicator de stivă SP, cu valoarea conținută în 
registrul dublu IX. 

Codul instrucţiunii ocupă 2 octeți: DD,F9+ (ar putea cineva să ne spună 
codul instrucţiunii LD SP,HL ?) 

Execuția durează 10 cicluri de tact repartizate în două cicluri mașină : 4, 6 


srezu PERETE iza 
E RS VA nl a MC 1C TRACE FAST 


„IN 
NM 
MA 
MREG mir 
16RG 
RD COMMAND 
WR 
CIRCUIT 
BUSFA 5 
„ BUZA 
FESET 
Hal. T 
FFSH 
WU IT 


= 1m,56 


Din starea activă a registrului R și cea a numărătorului de tact (T=6 
deducem că cel de-al doilea ciclu mașină efectuat a fost un ciclu fetch extins 


Remarca 13 : Încărcarea indicatorului de stivă din alt registru este posibilă doar dacă, 
ca sursă se folosește unul din regiștri „privilegiați HL, IX sau IY. 
Ex. : Nu există instrucțiunea LD SP,BC! 
Astfel numărul modurilor de încărcare a indicatorului de stivă SP se ridică la 3: 

— încărcare imediată : LD SP, număr 

— încărcare directă din memorie: LD SP, (adresă) 

— încărcare din alt registru: LD SP, rr unde rr poate fi HL, IX sau IY. 
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Instrucţiunea interschimbă conținutul registrului dublu IX cu cel al celor 2 
locaţii de memorie adiacente, care se află în virful stivei (adresa vîrfului stivei 
se află în indicatorul de stivă SP). 

Instrucţiunea ocupă 2 octeți în memorie: DDUE3H. 

Execuția se execută în 6 cicluri mașină, însumînd 23 tacți procesor: 4, 
4, 3,4,3,5. 

Datorită numărului mare de elemente vehiculate, datorită eleganţei şi fru- 
museții acestei instrucțiuni, o vom reda mai detailat: în modul ciclu mașină. 


ț; 3 CC ME IC TRA&CE FAST 


- 
LI 


eaIamm em-zzz- 
ÎnEmee BooR=a 


A witi 
ATAnra 


Im. 57 


La sfîrșitul primului ciclu mașină (fetch) s-a interpretat codul DD. 
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Urmează cel de-al doilea cod: 


SFEED  înă 
13 Cc MC IC TRACE FAST 
ADR ÎMNE:EX SF. IX ERE 
i 
7286 |COD: 0DEZ 


pr 


ERIC 


TE Tess | 


SF 7654 


PIEMCC AD0OA-2ZZ 


ZII £A-zzz- 


În ciclurile mașină M3 și M4 se citește virful stivei, cei doi octeți depunîn- 
du-se în ordinea cunoscută nouă, în regiștri temporari W și Z. 


IC TRACE FAST 
HME: E. SF, IX 
CCD: COE 


|p ee|e ea! 

| 
ti 
le] 
IFR E3 
R_e7 To 7T) 


Im.59 


COMHBIID 
CIRCUIT 


ZATADD Zaza 
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Observăm că SP a fost incrementat pentru a citi cel de-al doilea octet. 


auisareustzi 
SFEED 
4.5.6 MC IC TRACE FasT 


sia 
EET E3EEI ||... 
ti 


IN 
NM 
Mi 
MRE 
LOR! 
RD COMMAND 
WR 
CIRCUIT 
EUZFA 
ELIZA 
RESET 
HAL. T 
RFSH 
Wa T 


Începe acum transferul registrului IX în cele două locaţii din vîrful stivei. 
Ciclul M5 este un ciclu de scriere în memorie (WRITE). 


SITA CANRO 
ZFEEDI! 70 ! 
1 5 cc ME IC TRACE FAST 


ALR ză 
FOBE | COD: CLEZ 


iz 
| 


Im.61 


| 
R COMMAND 
UR 

CIECUIT 
EUZEG IFF1:8 
EUZARK 
RESET IFFZ:Qa 
HaL.T 
FFSH MOD :2a 
WAIT 
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Cel de-al doilea ciclu WRITE salvează ultimul octet 54, pentru ca apoi 
un ultim efort de voință (CM = 6; T = 5) să transfere conţinutul regiștrilor tem- 
porari W și Z în registrul selectat IX. 


Feerică această instrucțiune, asemenea unei zîne: frumoasă și periculoasă. 
SFEEC 


atzi 
RR = MC IC TFRACE FAST 


ADR |MNE:EX SF.iX 
7226 | COD: DDEZ 


COMMAND 
CIRCUIT 


IFF1:0 
IFF2:0 
MOD :a 


Im.62 


Remarca 14 : Doamne, ciţi tineri programatori am văzut pierzîndu-și nopţile cu eal 
Dar nu visînd, ci spărgîndu-și creierii în căutarea unor erori ascunse, cauzate de folosirea 
drematură a acestei instrucţiuni, Atenţie deci, băieţi ! (Trebuie cunoscut în fiecare moment 
conținutul vîrfului stivei, conţinut care se modifică cu fiecare instrucțiune PUSH, POP 
CALL, RET, RST). 


Remarca 15 : Virful stivei poate fi interschimbat doar prin 3 instrucțiuni dedicate. 
Partenerii posibili sînt: HL, IX, IY (mereu aceeași). 


Instrucţiunea este un exemplu de adresare directă: registrul dublu HL se 
încarcă din memorie de la adresa 7654(L) și 7655(H). Instrucţiunea ocupă 3 octeți 
în memorie : 2Au 544 76u. 

Execuția se face în 5 cicluri mașină, de-a lungul a 16 tacți: 4,3, 3, 3, 3. 

La sfîrșitul acestei instrucțiuni apare şi ,„,„compagnonul” nostru 76544, de 
astă dată în HL. 


Remarca 16 : Pe cînd 18080 putea încărca prin adresare directă doar registrul HL, la 
Z80 s-a implementat o grupă de instrucțiuni care tratează unitar regiștri dubli de bază: 


LD BC, (adresa) LD (adresă), BC 
LD DE, (adresă) LD (adresă), DE 
LD HL, (adresă) LD (adresă), HL 
LD SP, (adresă) LD (adresă), SP 
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| i COD . Zeta IRI ai a: na 
LMEISEEi | COD XDR AR i! DE) £ 


z-eoje ee] 


SP 78654 


COMMaNz 
CIRCUIT 


Im.63 


Meiileacă Lima e, 
ENEZICSEEI 


a-Zzz- 
0oz=iz 
am 
FI) 


COMMAND 
CIRZUIT 


SF 75854 
IETEZ ZA 
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STERD Li MC IC TRACE FAST 


ADR | MINE « aa ăi e (7: = | ANEI 
ee] : 


ii 


NE 

Mi 

MFEG TE ese _| 

RE COMaArID Liv _oeaa | bs r[eele] 
CIREUIT 

BUZFA 

EUZAGR 

RESET 

HaL.T 

RFZH 

Mi i T 


Im.65 


Aceste instrucțiuni se codifică pe 4 octeți: primii 2 octeți reprezintă codul (primul este 
ED ), iar ultimii doi adresa. Apare astfel situația interesantă ca instrucțiunile care implică 
registrul HL să fie dublu definite, prin 2 seturi de coduri. 


LD HL, (nn) LD (nn), HL 
24, AN NN pie 22, NN ow NN gh 
ED,68, nn AN pion ED, 63, nn nnpiah 


Se mai întîmplă | 


Această instrucțiune unicat, interschimbă conţinutul celor 2 regiștri dubli 
specificaţi. Ea ocupă în memorie un singur octet și se execută în 4 cicluri de 
tact. 


HL a devenit din nou 0 iar numărul 7654, apare de astă dată în DE. 


Remarca 17 : Faptul că acest schimb care implică 4 octeți de date s-a realizat într-un 
singur ciclu de tact (ultimul tact al ciclului fetch), ne sugerează ideea că de fapt nu s-a 
transferat nimic | Toată lumea a rămas pe loc — s-au schimbat numele regiştrilor: ce a fost 
DE se numeşte HL şi invers. Problema este rezolvată pe cale hardware cu ajutorul unui 
multiplexor, care dirijează semnalele de selecţie ale regiştrilor DE și HL. 


Instrucţiunea POP este o instrucțiune propriu-zisă de lucru cu stiva. Exemplul 
de față încarcă registrul dublu HL cu primii doi octeți din vîrful stivei, și ajus- 
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tează totodată şi indicatorul de stivă SP încît el să ponteze pe următorul grup 
de date. 

Instrucţiunea este scurtă (1 octet) și relativ rapidă, efectuîndu-se în trei cicluri 
mașină (4, 3, 3 tacți procesor). 

La sfîrşitul acestei instrucțiuni, SP a fost incrementat cu 2, (SP=7656,) 
iar în HL a apărut de unde, de unde, nu —7654,. 


“scc! mc! Ic YRACE FAST 


esa |eree| iza 
| 
i zel: 55 


INT LF_cs|ţe 

NUI 

Hi4 DEC 

HEEa EEE) 

LORE 

misi COMMAND aaa 
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PUSH, fiind instrucțiunea opusă celei precedente, este și ea o instrucțiune 
dedicată stivei. Exemplul de la adresa 700D salvează în virful stivei conținutul 
regiștrilor D și E. Totodată se ajustează indicatorul de stivă. 


Remarca 18 : instrucţiunea PUSH începe totdeauna cu decrementarea registrului SP. 
Astfel dacă înainte de instrucţiune SP conţinea 7656,,, înscrierea celor doi octeți s-a făcut 
la adresele 7655, (D) şi 7654, (E). 


Remarca 19 : Prin intermediul instrucțiunilor PUSH și POP se pot salva și restaura 
majoritatea regiştrilor interni, grupaţi cîte 2: BC, DE, HL, IX, IY și AF. 
Registrul din dreapta (C,E, L, X, Y, F) conţine octetul cel mai puțin semnificativ, care se 
salvează în memorie la adresa inferioară, (Virful efectiv al stivei). 
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Instrucţiunea încarcă cu adresare directă registrul dublu BC din memorie, 
de la adresele 7654 (C) și 7655 (D). Instrucţiunea face parte dintre cele 8 pre- 
zentate la Remarca 16, ocupînd 4 octeți în memorie și executîndu-se în 6 cicluri 
mașină însumînd în total 20 tacți procesor (4,4,3,3,3,3). 

lată-ne la sîrșitul aventurii a doua, întreprinsă în lumea instrucțiunilor de 
transfer pe 16 bit. (Acum și BC conţine 7654, .!). 


Cu ajutorul a 5 mnemonici (LD, EX, EXX, POP, PUSH) se realizează 39 
de instrucțiuni de transfer pe 16 bit, dintre care 33 unidirecționale și 6 bidirec- 
ționale. Cu excepția instrucțiunilor EX AF, AF', şi POP AF care încarcă registrul 
F, nici una din instrucțiuni nu afectează indicatorii de condiţie: 

Din punct de vedere funcțional am subîmpărțit această clasă în 10 grupe de 
instrucțiuni. 

Filele grupelor de instrucțiuni ale clasei LOAD—16 se regăsesc în partea 
a ll-a, COMPLEMENTE, $ E.4. 
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Microprocesorul Z80 permite, ca folosind o singură instrucțiune, (LDDR 
sau LDIR) programatorul să poată disloca blocuri de date de lungime programa- 
bilă (max. 65536 octeți). 


ltinerariul nostru nu face altceva decît să urmărească execuția instrucţiunii 
LDIR în modul ciclu maşină. Instrucţiunea LD D,H am introdus-o doar ca delimi- 
tator, 


Condiţiile iniţiale sînt : 
— adresa de început a blocului sursă: HL=7140, 
— adresa de început a blocului destinație: DE=7250, 
— lungimea blocului de transferat : BC=—0002,, 


Instrucţiunea citește un octet de la adresa indicată de HL, îl înscrie la . 
adresa indicată de DE, incrementează ambii regiștri dubli și decrementează regis- 
trul dublu BC. Dacă aceşta n-a ajuns încă la zero, atunci, totul se ia dela în- 
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8 — Totul despre microprocesorul Z 80 vol. | şi 2 
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Im.71 

ceput. Dacă BC == 0, instrucțiunea s-a terminat. Blocul de lungime BC-—iniţial 


a fost transferat de la adresa HL—iniţial la adresa DE—iniţial. 

Se citesc mai întîi cele două coduri : ED, și B0,, executîndu-se două ciclur 
fetch. 

Urmează transferul propriu-zis : 

De la adresa HL (7140,) se citeşte un octet (AA) și se depune în registrul 
tampon T. HL este incrementat (7141,,). 

Octetul citit (AA) se înscrie în memorie la adresa indicată de DE (7250,,) 
după care DE se incrementează (7251,.). 

În ultimele două cicluri de tact T=4 şi T=5 ale ciclului mașină (CM=04) 
se decrementează registrul dublu BC (inițial 0002) şi se verifică conţinutul lui. 
Rezultatul verificării se marchează în registrul de flaguri. Dacă acesta ar fi fost O 
instrucțiunea s-ar fi terminat. Așa însă, continuă. 

Urmează un ciclu mașină intern CM==5 avînd durata de 5 tacţi procesor, 
ciclu în care contorul program este repoziționat pe începutul instrucţiunii, care 
continuă prin reexecutare. 


Remarca 20 : Pentru a se asigura generarea ciclurilor de reîmprospătare a memoriilor 
dinamice, instrucţiunile multiple (LDDR, LDIR, CPDR, CPIR, INDR, INIR, OTDR, OTIR) se 
execută prin recitirea şi reexecutarea codurilor de instrucțiune în fiecare ciclu de transfer. 
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Reluăm deci întepînd cu adresa 7000, : 


sie ta, 3, Li * 
E ee ne TE TRE Fag ADU 


Fetch ED, : 
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Im. 75 
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urmată fe o nouă scriere în memorie din T la adresa DE (7551,,) 
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Contorul de octeți BC ajungînd la zero, ciclul mașină intern CM=05 nu se 
execută, aventura noastră luînd sfîrșit cu execuția următoarei instrucțiuni : 


Totalul instrucțiunilor din clasă este 4, împărțită în două grupe: 


transfer simplu : LDD 
LDI 

transfer multiplu : LDDR 
LDIR 


load & decrement 
load & increment 
load, decrement, repeat 
load, increment, repeat 


Filele grupelor de instrucțiuni din clasa LOAD-—IDR se găsesc în partea 


« Îl-a, COMPLEMENTE, $ E.5. 
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Indiferent la ce nu s-ar folosi calculatoarele în zilele noastre, începînd de 
la crearea și întreţinerea bazelor de date, pînă la comanda preceselor industriale, 
de la asistarea instruirii pînă la asistarea conducerii (CAX — cum spunea profe- 
sorul Jacques Hebenstreit; computer aided everything) trăsătura lor comună 
rămîne aceea că, pe lîngă multe alte facilități, ele știu să și calculeze. Întreba- 
rea, dacă instrucțiunile aritmetice sînt necesare sau nu, nu o mai punem. Ins- 
trucțiunile logice apar împreună cu aceste instrucțiuni de nesubstituit, datorită 
faptului că în aritmetica binară operațiile aritmetice de bază se efectuează tot 
prin funcții logice, Deci: dacă am să dau la alții, atunci înseamnă că am și eu 
(nu-i așa ?). Instrucţiunile aritmetice se regăsesc împreună cu cele logice în orice 
calculator, ele fiind prelucrate de către aceleași circuite electronice : unitatea 
aritmetică/logică (ALU), 

Celor care mai contestă importanța software-ului, dacă ei mai există —, 
le recomandăm ca după studierea atentă a prezentului capitol să încerce să 
scrie un progrămaș, folosind instrucțiunile microprocesorului Z80, care să cal- 
culeze Icgaritmul natural al oricărui număr real pozitiv, măcar cu o precizie de- 
6 cifre semnificative. Lucru elementar, pe care-l știe orice calculator personal 
(deci și cele realizate-cu microprocesorul Z80), din naștere. 


Noi ceilalți, să ne întoarcem la cabana noastră (70004) pentru a pregăti o nouă 
„ncursiune, 
lată itinerariul ales : 
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Reamintindu-vă că toate instrucțiunile aritmetice/logice se efectuează între 
doi parametri, dintre care unul va trebui să fie locat obligatoriu în registrul A, 
să pornim la drum. 


Instrucţiunea realizează operația logică SAU EXCLUSIV între conținutul 
acumulatorului și el însuși. Rezultatul operaţiei este desigur zero. Aceasta este 
cea mai scurtă instrucțiune (un octet) pentru ștergerea acumulatorului, și pozițio- 
narea adecvată a flagurilor. (LD A,00 ar necesita 2 octeți și nici nu poziţionează 
indicatorii de condiţie). 

Instrucţiunea XOR r unde r poate fi oricare din regiștri interni, ocupă un 
byte și durează 4 tacți procesor, 


C'28 
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COMMAND 
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Remarca 21. Folosind modul de lucru IC, ne-am fi așteptat ca starea ilustrată în 

Im. 78 (sfîrșitul instrucţiunii), să fie caracterizată prin CM=1 și T=4, Indicaţia din Im. 78 

(CM=XX), T=2) se cere a fi explicată. 

În realitate cei 4 tacţi procesor afectați ciclului fetch (M1) nu sînt suficienţi pentru 
efectuarea operațiilor aritmetice/logice. lată de ce: 

— în tactul T3, codul instrucţiunii se depune în registrul de instrucţiune IR și începe deco- 
dificarea ; 

— în tactul T4 conţinutul registrului selectat și cel al acumulatorului este adus la cele 2 
intrări ale ALU ; 

— pentru a reînscrie rezultatul operației, obținut la ieșirea ALU, în acumulator, mai este 
nevoie de un ciclu de tact suplimentar. În modul cel mai simplu problema s-ar fi putut 
rezolva suplimentînd ciclul fetch cu încă un tact. În acest caz instrucțiunea s-ar fi terminat 
în starea CM=1 ; T=5. 

Cunoscînd însă faptul că ultima operaţie de efectuat (transfer ALU—A) este o activitate 
internă procesorului, execuţia ei poate fi amînată pe durata ciclului mașină următor, 
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ciclul mașină care este primul ciclu mașină al unei instrucțiuni următoare. De aceea 
notația CM=XX, Dar ce înseamnă T=2? Aceasta este o moștenire de la microproce- 
sorul 18080, la care transferul ALU—A nu s-a putut efectua în primul ciclu mașină T=1 
al instrucţiunii următoare, datorită faptului că magistrala internă de date a procesorului 
era ocupată cu emiterea „cuvîntului de stare''. Deci transferul ALU—A a trebuit să fie 
amînat pe cel de-al doilea ciclu de tact, T=2. În documentaţiile publicate de către fabri- 
canții microprocesorului Z80 nu se face nici o referire la acest detaliu. De aceea, în 
VISIBLE—Z80 noi am adoptat varianta publicată, cea de la Intel. Menţionăm că după 
părerea noastră în microprocesorul: Z80 transferul ALU—A se efectuează în primul 
ciclu de tact (T=1) al noii instrucțiuni, căci spre deosebire de 18080, magistrala internă 
de date a microprocesorului Z80 este liberă în acel moment. 

Tehnica folosită, cea de a amina finalizarea unei instrucțiuni (sau a unei operaţii interne), 
pe durata ciclului mașină următor, atunci cînd procesorul execută manevre externe, se 
numește suprapunere de cicluri mașină (sau „furt de ciclu''). Scopul suprapunerii de cicluri 
mașină este cel de a spori viteza de execuţie. Știind că astfel instrucţiunile aritmetice/lo- 
gice se vor executa în 4 tacți procesor în loc de 5, constatăm că sporul de viteză este 
semnificativ ; 20%, 


Remarca 22. Instrucţiunile logice propriu-zise sînt: 

AND (SI), XOR (SAU EXCLUSIV), OR (SAU) 

Instrucţiunea de comparație a doi octeți este de fapt o scădere, dar întrucît rezultatul 
ei nu se generează, ea poate fi privită ca o instrucțiune logică relațională : =, >, <. Aceste 
informaţii se pot extrage din starea indicatorilor de condiţie. Instrucţiunile logice propriu- 
zise, se efectuează bit cu bit între un bit al registrului A și registrul implicat în operaţie, 
biții operanzi avînd aceeași poziţie semnificativă în cadrul octetului. Octetul rezultant se 
"eînscrie în acumulatorul A, 

Tabelele de adevăr ale celor trei funcţii logice propriu-zise sînt redate în fig. 6.1. 


bxA br DA 


SAU EXCLUSIV SAU 


Fig, 6.1. Tabelele de adevăr ale celor 3 funcţii logice de bază 


Remarca 23. În afara destinaţiei lor de bază, cea de a calcula expresii logice, funcțiile 
logice pot fi folosite eficient pentru a șterge, a înscrie sau pentru a completa un bit sau un 
grup de biţi ai unui octet. 

Fie octetul pe care dorim sa-l manevrăm, în registrul A. Notăm biții interesanţi cu b, 
Într-unul din regiștri interni depunem un octet numit mască, în care biții b; vor avea o 


stare, iar toţi ceilalți starea comp'ementară. lată operaţia și tipul de mască recomandat: 


Tabela €.:;, Tehnici de mascare a biţilor 


Efectul dorit Operația folosită Starea biţilor de mască b, 
Ștergerea unor biţi b,; AND (ȘI) b; =0 

Inscrierea unor biţi b; OR (SAU) b; = 

inversarea unor biţi b; XOR (SAU EXCLUSIV) b; = 
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Aruncînd o ultimă privire fugitivă asupra Im.78 observăm că flagul Z (zero) 
s-a înscris. Încărcăm în acumulator un număr din memorie, așa cum se vede 
în lm.79 folosind instrucțiunea LD A,(DE). 
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Valoarea înscrisă este 99p căci o considerăm ca fiind reprezentată în BCD, 


Instrucţiunea de față adună la conținutul acumulatorului valoarea din celula 
de memorie a cărei adresă se găsește în HL și la rezultatul astfel obținut adaugă 
valoarea indicatorului de transport (flagul notat cu C în registrul F). 

Instrucţiunea ocupă un byte în memorie (9E,,) și se execută în două cicluri 
mașină însumînd 7 taci (4. 3). i 

Întrucît în Im. 80 instrucțiunea a fost executată în modul IC, ciclul mașină 
indicat este. ca și la instrucțiunea de mai sus (XOR A), ciclul ascuns (CM = 
=XX, T1=2) 

Octetul citit din memorie se află în registrul tampon din dreapta, vechiul 
conținut al acumulatorului în registrul tampon din stînga, iar rezultatul în A. 


Într-adevăr A = A+ (HL) + Cy =99 +01 +0 =9A4 


Remarcăm faptul că ALU nu știe dorința noastră și anume că 99 este un 
număr BCD. El tratează toate numerele ca și binare. De aceea pentru a obţine 
rezultatul sub forma dorită (BCD), după efectuarea operaţiei aritmetice se va 
aplica o corecție prin instrucțiunea DAA așa cum vom vedea la adresa 7003, 
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Pînă atunci să mai facem cîteva observații : 


Remarca 24. Instrucţiunile aritmetice pe care microprocesorul Z80 le poate executa 
sînt: ADD — adunare simplă 


ADC — adunare cu adunarea transportului 
SUB  — scădere simplă 
SBC  — scădere cu scăderea transportului 


Al doilea operand poate fi locat fie într-un registru intern, fie în memorie. În funcție 
de tipul de adresare folosit, distingem 3 grupe de instrucțiuni: 
a) operaţii aritmetice cu adresare implicită (op, în registru) 


ADD A,r A=A+r 
ADC A,r A=A+r+ Cy 
SUB r A=A-—r 
SBC  A,r A=A=—r — Cy 


unde r poate fi unul din regiștrii B, C, D,E, H, Lsau A, iar Cy este indicatorul de trans- 
port. 
b) operații aritmetice cu adresare indirectă sau indexată (op în memorie) 


ADD A, (mem) A = A + (mem) 
ADC A, (mem) A = A + (mem) + Cy 
SUB (mem) A = A — (mem) 

SBC A, (mem) A = A — (mem) — 


unde mem poate fi HL, IX+FIND sau IY+IND. 


(Regiștri BC și DE nu pot fi folosiți ca mijloc de adresare indirectă, la această clasă de 
instrucțiuni |) 


c) operaţii aritmetice cu adresare imediată (op, în memorie, în cîmpul instrucţiunii) 


ADD A,n A = A+n 

ADC A,n A = A+n+Cy 
SUB n A=A-—n 

SBC  A,n A=A-—n—Cy 


unde n este un număr binar de 8 bit [0,255]. 
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Suindu-ne din nou pe cal... 


Instrucţiunea ajustează numărul obținut din însumarea sau scăderea a 2 numere 
BCD, la formă BCD 
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Im. 81 


La adunarea precedentă, ne-am așteptat ca rezultatul să fie: 990 +01 = 
=100p, dar s-a obținut 9Au. După instrucțiunea DAA (Im. 81) rezultatul din 
acumulator a fost reajustat la valoarea BCD corectă (A = 00; Cy=1 = rez = 
= 100). De aceea ea se numește DAA (Decimal Adjust Accumulator). 

Folosind flagurile N, H și Cy, reajustarea se face aproape instantaneu, ins- 
trucțiunea executîndu-se într-un singur ciclu mașină (4 tacți procesor). 


Remarca 25: Dacă numerele implicate într-o operaţie aritmetică nu sînt ambele 
numere BCD, atunci nici DAA nu poate ajusta corect rezultatul. 


Pînă una alta, stocăm rezultatul obținut (A=00) în memorie la adresa in- 
dicată de HL (7100), folosind instrucțiunea de la adresa 7004 (LD (HL), A). 
lar apoi : 


Incrementarea cu 1 a conținutului registrului intern E și L 
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Ambele instrucțiuni se execută în cîte 4 cicluri de tact, dar necesită fizic 5. 
Ultimul (CM = x x, T=2) se suprapune peste primul ciclu mașină al instrucţiunii 
următoare. Din Im. 83 și Im. 84 observăm: că în operația de incrementare se 
implică doar una din căile de acces ale ALU. 


Remarca 26 : Increrhentarea regiștrilor simpli se face în ALU, dar nu prin adunarea 


cu 1 ci printr-un automat hardware specializat. 
Aceeași observaţie este valabilă și pentru instrucțiunile de decrementare DEC a căror 


structură și execuție este similară cu cea a instrucţiunilor INC. 


Forma generală este: INC r 
DEC r 
unde r poate fi B,C,D,E,H,L sau A. 


Remarca 27 : Folosind adresarea indirectă sau cea indexată, este posibilă incrementarea 
sau decrementarea unor celule de memorie, dar numai prin utilizarea mereu acelorași regiș- 


tri privilegiați HL, IX, IY. 


INC HL respectiv DEC HL 
INC (IX+IND) DEC (IX+IND) 
INC (IY+IND) DEC (IY+IND) 


Inchidem aici secvența de aritmetică într-o buclă, folosind o instrucţiune 
care face apel atît la resursele instrucțiunile aritmetice cît și a celor de salt. 


Instrucţiunea de față (Decrement Jump if Not Zero), decrementează con 
ţinutul registrului B. Dacă rezultatul este diferit de zero se execută un salt 
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relativ, adăugînd numărul specificat în enunţul instrucţiunii, la valoarea curentă a 
contorului program PC. În caz contrar se execută instrucțiunea următoare. 


Numărul se consideră a fi un număr cu semn, exprimat sub forma comple- 
mentului față de 2. În cazul nostru F8=—8 înseamnă un salt înapoi cu 8 adrese, 
urmînd ca programul să fie continuat (reluat) de la adresa 70074 +2 —8 = 
= 70014. (vezi PC din im. 85). 
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Oprindu-ne în modul IC la sfîrșitul execuţiei acestei instrucțiuni constatăm 
că DJNZ ocupă în memorie 2 octeți și se execută în trei cicluri mașină, însumînd 
13 (5,3,5) tacți procesor. Ultimul ciclu mașină (M3) este un ciclu intern și se 
folosește la calculul sumei PC + depl. Dacă B = 0 saltul nu se mai efectuează 
şi deci nici ultimul ciclu mașină (M3) nu mai este necesar, durata de execuţie 
a instrucţiunii reducîndu-se la 8 cicluri de tact (5,3). 


Remarca 28: DJNZ este o instrucțiune unicat, ea decrementind totdeauna registrul B. 
Datorită faptului că deplasamentul se specifică pe un singur octet ca număr cu semn, 
ecartul saltului este limitat la [4-127, —128] față de adresa instrucţiunii imediat urmă- 
toare. (În momentul calculului adresei de salt, PC conţine deja adresa instrucţiunii ur- 
mătoare. Toate salturile relative ale microprocesorului Z80 (le vom cunoaște) sint limitate 
la acest interval. 


Cum în aventura noastră B=1, diferit de zero, reluăm execuția instrucțiunilor 
începînd cu adresa 7001,. 
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TAUIRGINRAL287006 MAG RATE 
SPEED PE. Pi hii 
sa 3 n zi ME IC TRACE Fast 

sc 


Dom-ZZ 


COMMAND 
CIRCUIT 


ZALAND £A-222-— 
PNEmMCC 2 


Im..86 


Flagul Cy fiind înscris de la precedenta execuție DAA, ADC A,(HL) din 


Im. 87 va genera rezultatul : 04+9+1 =0A. 
SFEELPEO PR pere parere rep pop porere? 
1 356 M IE TRACE Fa 


| DORI, PCA RN RR A 
ACR |MHE: =i « 
pp pepe | 2 a fi 

ţ 

i 

i 

i 

i 


SE DR 


Sulcacă | COC : 20009 
„PR N N II NE N 


INT 

NM | 

Mi 

MRE& 

LORE 

4”) COMMAND lv Basa 
" CIECUIȚ ZF 7FEBO 

EU 

EU = 

RE£E 

HA 

RF 

A 


Im.87 : 


9 — Totul despre microprocesorul 2 Sa vol. 1 şi 2 
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în A: 


ă 


se obține valoarea scontat 


Reajustindu-l prin DAA 


TRACE Fei 


= 
= 


WIC'aA 


1 


a 


Mu] 


Cititi 


u 
LR 


Die Dudu 
253 bmaele 


IT 


ț 


(Im. 88) 
Valoare pe care o vom salva din nou în memorie (lm.89). 


9+1 = 10p 


= 
& 
Li 
bi. 
i 
UL) 


P; 


miei lu [land 
ZIEIIIT 


Ta : abea 
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După incrementarea regisștrilor E 


AEM de RRZ POR PCD CCARIAI 
SFEED ara) 
1 Si Ei ME IG TRECE. FAST 


COMHeatiD 


CIRIZULT 
IFF1:8 


IFFz:a 
PAD A 


a 


d pre m e a 


N Im. 90 


ENCZICSL 


COMMAND 


CIRCUIT SF _7E0a 
IFF1:0 - 
IFF2=:08 


MOD :4 


Im.91 
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testăm din nou condiția de terminare a ciclului program, 


SFEEC aaa 


ii 
3 ce MC IC TRACE FAST 


COMIAGID 
CIRZIILT 


SF 7EO09 


IFF+:a 
IFFz:a 


IA 


20 


De astă dată, B fiind O, execuţia instrucţiunii DJNZ se termină la ciclul mașină 
M2 (vezi lm.92) și aventura noastră continuă la adresa 7009,.. 


cc MC 


SPEED 


13 


IC TRACE FAST 


o'eo|e'ae 
bad) Im.93 


COMMAND 
CIRCUIT SF _ 7EQQ 
FC 78 
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Această instrucțiune am gîndit-o ca închizător de aventură, dorind ca ea să 
execute un salt „pe loc”, la infinit. 

Greșind însă valoarea deplasamentului (FF în loc FE) saltul nu se efectu- 
ează „tot pe loc, pe loc, pe loc" (7009,.), ci la adresa 70044, unde găsim „„instruc- 
țiunea”' FF (RST 38H) ceea ce este cu totul altceva! 


Remarca 29 : Ne-a fost dat să cunoaștem softiști de înaltă clasă greșind mereu valoa- 
rea deplasamentului !a salturile relative. De aceea e bine să cedăm această operație de 
rutină unuia care se pricepe mai bine, programului asamblor de exemplu. 


Clasa instrucțiunilor aritmetice/logice pe 8 bit cuprinde în total 115 instruc- 
țiuni. Din punct de vedere funcțional ele au fost împărţite în 26 de grupe. 

Mnemonicile instrucțiunilor din această grupă sînt: ADD, ADC, SUB, SBC, 
AND, XOR, OR, CP, INC, DEC, CPL, NEG, DAA, RLCA, RRCA, RLA, 
RRA. 


Într-un fel sau altul, toate instrucțiunile clasei afectează indicatorii de con- 
diție. 
Instrucţiunile neatinse în aventura a 4-a sînt: 


CPL — complementul față de 1 al acumulatorului 

NEG — complementul față de 2 al acumulatorului 

RLCA, RRCA, RLA, RRA — rotiri la stînga și la dreapta, „cu” respectiv 
„„prin”" carry a acumulatorului, 


lată-ne din nou la 7000. 
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Secvența aceasta este o subrutină, fiindcă se termină cu instrucțiunea RET 
Aventura de față s-ar putea să-i plictisească pe cititorii care ne-au urmărit atent 
pînă la acest punct, fiindcă baleind progrămașul de mai sus, li se pare totul clar. 
Să-l parcurgem totuși cu ajutorul lui VISIBLE— Z80, știind că chiar și o plimbare 
in propria-ți curte poate fi cîteodată reconfortantă. 


Salvăm conținutul registrului dublu HL pe stivă, 


ZFE er o udă Via mu at ai e PI) 
TA 5 cc MC IC TRACE FAST 


COMMAND 


CIECULT 
IFF1:08 


IFF=:a 
HOD :a 


Im.94 
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și apoi îl adunăm la el însuși: 


i i 
=? za ce ME 1e TEBCE FAST 


EEE EEE) re 


(w ea |z ae | 


15 
NM 
MA 
MR 
IG 
RD COMMAND 
LIR 
CIRCUIT 
EL 
EU 
FE 
Ha 
RE 
Lil] 


Im.95 


Oprindu-ne la sfîrșitul celei de-a doua instrucțiuni, ADD HL,HL constatăm 
că ea se codifică pe un byte, iar execuția durează 3 cicluri mașină însumînd 11 
tacţi procesor (4,4,3). M2 și M3 sînt cicluri interne menite să efectueze adunările 
și transferurile aferente. 

Din faptul că registrul A n-a fost implicat pe parcursul instrucţiunii (căsuţa 
lui nu s-a înegrit în Ilm.95) deducem o concluzie importantă. 


Remarca 30 : în aritmetica pe 16 biţi a microprocesorului Z80, rolul aculumulatorului 
este preluat de registrul dublu HL și confrații săi de breaslă IX și IY. 


Știind că în aritmetica binară înmulțirea cu 2 este echivalentă cu o deplasare la stînga, 
corelată cu inserarea unui bit O pe poziția cea mai puţin semnificativă, constatăm că ADD 
HL, HL poate fi privit ca o deplasare pe 16 bjt cu o poziţie la stînga: 


1234, — 0001 0010 0011 0100 
2468, — 0010 0100 0110 1000 


În aritmetica pe 8 bit, aceeași funcţie s-ar fi realizat prin ADD A, A. 


Repetăm adunarea ADD HL,HL pentru a vă sugera ideea că a repeta de 
n ori această instrucțiune are același efect ca și HL x 21 
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ZFEED 
+9 cc MC 


COMAND 
ZIETZULT 


gA-z22= 

N00N-Z2 
AM —-A 
22 


AT 


Citim în registrul DE ultima valoare depusă pe stivă (7000 PUSH HL). 
lar apoi efectuăm o adunare clasică a registrului DE cu HL, obţinînd rezul- 
tatul în HL. 


Remarca 31 : Aritmetica pe 16 biţi a microprocesorului Z80 admite un singur tip de 
adresare, cel implicit. Al doilea operand va fi plasât într-unul din regiștrii BC, DE,HL 
sau SP. 


Remarca 32 : Instrucţiunea ADD HL, SP precedată de o ștergere a registrului HL 
este una din puţinele instrucțiuni, prin care se poate determina, în cursul execuţiei unui 
program, valoarea curentă a indicatorului de stivă SP. La microprocesorul 18080, instrucțiu- 
nea echivalentă DAD SP era unică). 


Remarca 33 : În rutinele de aritmetică este necesară adesea ștergerea indicatorului 
- de trarisport Cy. Cum nu există o instrucțiune dedicată acestui scop, putem folosi instruc- 
țiunea OR A sau AND A cu același efect. 


Ajungînd la imaginea nr. 100, să-i dăm cezarului ceea ce i se cuvine, deru- 
lînd din nou o instrucțiune în modul ciclu mașină (MC). 
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Piti 


E DE i = <a MC IC TRACE FAST 


EREI 


HM F ZE | (ln 
MA EX |_2e | DEEA 
MREQ 
LORE 
pi COMMAND LY_ 20288 

CIRCULȚ SP  7EOa | 
EUSF& IFF1:Q2 
EUZARK 
RESET IFFZz:A 
a = MOD :a 
WI T 

Im.97 
E i id i Aa dă 
SPEED aaa 
+35 MC IC TRACE FAST 


ADR |IMNE : Sadu z1 MR 00 | 7:03) 
se] 


CIRCUIT 
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MC IC TRACE FAST 


INT 
NMI 
Mi 
MREG 
LORE 
Rp COMMAND 
CIRCUIT SF __7E00 
BUS 
BUE. 
RESE 
EPEn 
WAIT 
Im.99 
x. Ț 7 ai 
1 3 „el und uz iC TEACE FAET 


Im. 100 


SFEED Pr _âra 
ce Mc TE TRACE Pas. AU 


4.83 
WADE IMNHE:SEC HL.EC [? es | | 
7a2€e 


Im.101 


Pînă aici am citit și interpretat cele 2 coduri de operație ED, și 42,.. 

În ciclul M3 'octeții mai puțin semnificativi sînt trecuţi prin ALU, rezultatul 
scăderii L—C înscriindu-se în L (Im 102). 
(Observăm și aici graba lui VISIBLE—Z80 care execută M3 în 3 cicluri de tact, 
în loc de 4 cum se întîmplă de fapt). 


lar apoi este rîndul octeților celor mai semnificativi să viziteze ALU. Rezultatul 
este: H=H BB. (li 193) 


Remarca 34: Z80 cunoaște în total 3 tipuri de operaţii aritmetice pe 16 bit. 


lată-le : 
ADD HL,rr ADD IX,rr ADD IY,rr 
ADC HL,rr — — 
SsBC HL, rr — -- 


unde rr poate fi: 
BC, DE, HL, sP BC, DE, IX, SP BC, DE, IY, sP 


Instrucţiunea SUB nu este implementată. 


Incrementarea regiștrilor dubli se face într-un singur ciclu fetch extins (CM=1, 
T=6). 
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PEEDPEEF Ferrer E aEAzI 
ari: > ce MC IC TRACE FAST 


ADR ÎMNE:SBC HL.BEC 
4 
7006 |coD:E042 


z 


N [e 32] ea] 
Mira IX 2998 
LORE 

9 COMMAND IY 2298 


SP  7E09 


CIRCUIT 
IFF1:0 


IFF2:0 
MOD :2 


nt 
Iri] 
2) 


Sare ea 
4x92 


2uP 
AIA 


Im.102 


ZPEECI Piti] 
1-9 CC MC IC TRACE FAST 


ADR ÎMNE:SEC HL.EC DE 42 
7006 Ț- 


IY 9228 


SF 7E00a 


Ş 


BE 78221 


COMMAND 
CIRCUIT 


Im.103 


sPeeD PEREȚI E znazi 
1 3 Cc MC IC TRACE FAST i 


aaa (op 12|£ 234| 
|H_se [I.E 


Im.104 


Remarca 35 : În simplitatea lor instrucțiunile de incrementare INC rr, decrementare 
DEC rr a regiştrilor dubli sînt foarte democratice, ele putîndu-se aplica tuturor regiștrilor 
dubli tip adresă: BC, DE, HL, IX, IY și SP. 


Remarca 36 : incrementarea, decrementarea regiștrilor dubli se face independent de 
ALU, folosind același modul electronic care asigură și incrementarea automată a contorului 
program PC în cazul execuţiei programelor cod maşină. 


Încheiem aventura a S-a regrupînd rezultatele, 


şi părăsind subrutina 


Aruncînd o privire de adio asupra Im.106 trăim un regret: faptul că n-am 
început aventura 5-a cu registrul BC poziționat la 5B05,.. 
Dacă am fi procedat așa, am fi avut măcar satisfacția de a fi ajuns la același con- 
ținut (cel inițial) al regiștrilor BC, DE, HL, după ce i-am folosit intens cu instruc- 
țuni aritmetice pe 16 bit. 
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SPEED PERETE eE Ț. a00al 
1 9 C<. MC : IC TRACE FAST 


aj 
e 
= 


OD|E BE 


BE 
IE E) 
[=] 3 


I|D 
9 
9 
Sir 
9 
9 


ilie 
td | [2] 
+. | [2] 
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INT 
NMI 
M1 
MREG& X ruDru Dra Leu] 
LORG 
RR COMMAND Li d aaaa 
CIRCUIT SF __ 7EOQ 
EUSRG IFF1:8 
EUSAH 
RESET IFF2Z:28 
EPE MOD: a = 
Wa i Ț = SA: > 
Im.105 
„NA APOASE TROAS, 
SPEED 
185 se a MC 1€ TRACE Pasi 


COMMAND 
CIECUIT 


Clasa instrucțiunilor aritmetice pe 16 bit numără 32 de instrucțiuni distincte. 

Mnemonicele prezente în această clasă sînt: 

ADD, ADC, SBC, INC, DEC 

Rolul acumulatorului este preluat de registrul dublu HL. 

La instrucțiunea ADD același rol îl pot avea regiștri IX și IY. 

În întreaga clasă se folosește un singur tip de adresare, cel implicit, operanzii 
instrucțiunilor fiind locați obligatoriu în regiștri interni ai microprocesorului Z80. 

Din punct de vedere funcțional, am împărțit cele 32 de instrucțiuni în 7 


grupe. 


Liniștea dinaintea furtunii. Vom trata această clasă de instrucțiuni, fără a 
recurge la serviciile lui VISIBLE—Z80 menajîndu-vă ochii înaintea ultimelor 5 
aventuri. Un scurt respiro la jumătatea drumului, 

Unicul tip de instrucțiune al acestei clase este cel de comparaţie. În 4 moda- 
lităţi diferite se compară octeţii unui bloc de date din memorie cu conținutul 
registrului A, 

Acţiunea de bază a clasei este aceeași ca și cea a instrucţiunii de comparaţie 
Gps 

A — (HL) 


Rezultatul numeric al scăderii nu se generează, informaţiile logice relaționale 
(=,>, <) putindu-se extrage din registrul indicatorilor de condiţie F. 

Cele patru mnemonice includ în numele lor inițialele CP. 

Ori de cîte ori vom dori să localizăm prima apariție a unui octet dat într-un 
bloc de date din memorie, vom recurge la serviciile uneia din instrucțiunile clasei 


LOG-—IDR., 


Totalul instrucțiunilor : 4 
Mnemonicele prezente : CPD, CPI, CPDR, CPIR 


Semnificația mnemonicelor : 


CPD  — compare & decrement (compară și apoi decrementează) 

CPI — compare & increment (compară și apoi incrementează) 
CPDR — compare, decrement, repeat (compară, decrementează, repetă) 
CPIR  — compare, increment, repeat (compară, incrementează, repetă) 


Tipuri de adresare folosite : 
— implicit pentru A 
— indirect pentru octeţii blocului de date baleiat. 
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În capitolele 5 și 6 am avut posibilitatea să realizăm importanţa instrucțiu- 
nilor aritmetice/logice, și a celor de transfer. Așa cum probabil vă dați seama, 
ele sînt însă insuficiente pentru implementarea pe calculator a unei probleme 
oricît de simple. Pentru ca într-un program să se poată lua decizii, în funcţie de 
valoarea instantanee a unui eveniment extern, sau în funcție de valoarea calcu- 
lată a unei variabile, sînt necesare instrucțiuni de salt. Pentru ca un program 
să fie cît mai scurt, păstrînd totodată o structură elegantă și inteligibilă, se cer 
subrutine și instrucțiunile de apel și de revenire din acestea. 

Aceste instrucțiuni, care determină structura unui program și dirijează exe- 
cuţia lui, își conjugă eforturile cu alte instrucțiuni aparent mai mărunte și mai 
puțin semnificative, deservind instrucțiunile aritmetice și logice pentru a realiza 
obiectivul propus al programului în care au fost incluse. Ele muncesc din plin. 


lar importanța celor ce muncesc, o cunoaștem cu toții. 


Pe parcursul căreia vom avea prilejul să vedem în acțiune instrucțiunile apar- 
ținînd la 4 clase noi: instrucțiuni de salt, instrucțiuni de apel și revenire din 
subrutine, instrucțiuni orientate pe bit și instrucțiunile de rotire și deplasare a 
octeţilor din regiștri sau celule de memorie. 


lată itinerariul ales. 
Programul principal : 
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Subrutinele : 


și 


Să pornim la drum pornind de la adresa noastră, adresa 7000H. Fie-ne par- 
tener trecător, un bit ,„,1'', care ne va însoți în aventură, lăsînd să tresară „,ini- 
mile" cîtorva regiștri, pentru ca în final să dispară fără urmă, bucuria cunoș- 
tințelor acumulate de astădată fiind unica în măsură a ne permite să uităm regre- 
tul de-al fi pierdut. 


instrucțiunea BIT ne permite să testăm starea oricărui bit din regiștri de uz 
general, sau a oricărei celule de memorie adresată indirect sau indexat (prin 
HL, IX+FIND sau IY+IND). Ea copiază în indicatorul Z (zero) al registrului de 
flaguri F, valoarea complementată a bitului dorit. Astfel devine posibilă ramifi- 
carea programului, folosind instrucțiunile de salt condiţionat care acționează în 
funcție de starea indicatorului Z. Dar înainte de asta să vedem cum” funcționează 
instrucțiunea de faţă: BIT 7,A. 

Instrucţiunea ocupă 2 octeți în memorie și se execută în-2 cicluri mașină 
M1 (ambii octeți fiind octeți de cod) însumînd 8 tacți procesor (4,4), 

În primele două cicluri mașină (Im.107, lm.108) se interpretează codurile 
CB și 7Fu. 


10 = Totul despre microprocesorul Z 80 vol. 1 şi 2. 145 
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SFEED 
13 cc ME IC TRACE FAST 


ADR [MNE: 
sata] 


CAIN 4-22 
PNEMCC N00A-22Z 


Im. 107 


ADR |IMNE:BIT 7.A 
7aaa 


] 


La 


[= 


Urmează ciclul suprapus în care instrucțiunea este executată fizic (CM=XX 
T=2). Înainte de a-l vedea rememorăm că Z=0 și bit, al registrului A este 
și el O. 


SFEECQ 
Ta E HE !€ TRACE Pag Lt 


ADR IMUE:BIT 7 


7FADa |COD. EE7F 


| 
ku 


u 
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sam atmeaareeu e, 
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; 
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COMMAND 
CIRCUIT 


IFF1:0 
IFF2:a 
MOD :8 


| Inlw 
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s| leln 
-| lele 
| |n|8 


j 
8|$ 
i i, 
E omenceaae s 
pu d 


Im. 109 


După execuţia ultimei secvenţe din instrucțiune (1m.109) Z=1 = bit/A. 


Remarca 37 : Instrucţiunea BIT ar fi putut copia desigur şi bitul real (nu complemen- 
tul lui). Această inversare este necesară pentru a corela acțiunea instrucţiunii cu semantica 
mnemonicelor instrucțiunilor de salt condiţionat. 


Cînd spunem “jump if not zero" („salt dacă diferit de zero'') ne referim nu la conți- 
nutul flagului Z ci la semnificaţia conţinutului lui. Într-adevăr, starea Z=1 înseamnă că 
elementul testat (octetul din registrul A sau un bit selectat) este egal cu 0. 


Să testăm deci condiția aleasă : 


Instrucţiunea de față este una din cele 8 instrucțiuni de salt condiționat 
absolut, care folosesc adresarea directă. Dacă condiţia testată NZ, este adevă- 
rată atunci se efectuează saltul la adresa specificată în enunţul instrucţiunii. În 
caz contrar execuţia programului continuă cu instrucțiunea următoare. 

Fizic, saltul se efectuează înscriind adresa de salt în contorul program PC. 
Instrucţiunea ocupă 3 octeți în memorie (unul de cod și 2 de adresă) și se execută 
în 3 cicluri mașină avînd un total de 10 tacți procesor (4, 3, 3). 
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Să le vedem: 


FE: PERETE ia 
seg ce MC IC TRACE FAST 


ADR | MINI : sala: PONI | aaa | 
audă | COD : aetuT:2054 III 


i 
lez| 


I-Z3z2- 
DOA- 32 


Rae 5 


Z2I 


S-a citit și interpretat codul instrucţiunii : C2u. 
Urmează octetul cel mai puțin semnificativ al adresei de salt (O0A,,) care se 
depune în registrul temporar Z (a nu se confunda cu flagul 2). 
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"SPE. FE ereeT Tre 
chei cc MC IC TRACE Pas A 


ADR ÎMNE:IP NZ.7004 
7082 |coD: c2z0a7a 


COMMAND 
CIRCUIT 


După care se citește octetul cel mai semnificativ al adresei de salt: 


i Ş cc ME Lă= TRRCE FasT 


FE 
ADR MNE:IJP NZ.7904 r) = ș 
7aeajcon:caoaza | mătaist| 


ha 


NM 
Mi € DECOD 
"BEE 
R COMMAND 
uIR 

CIRCUIT 
BUSRE IFF1:0 
BUZAK 
REDET 1IFF2:0 
HAL 
RFESH MOD :8 
WAIT E 


Im.112 


Citit în ciclul mașină M3 octetul 70, se depune în registrul temporar W. 


Cum condiţia stipulată în enunţul instrucţiunii (salt dacă diferit de zero) 
nu este adevărată — bit, din A fiind O — saltul nu se efectuează, execuția 
programului continuînd cu instrucțiunea următoare, locată la adresa 7005, (valoarea 
curentă a contorului program PC). 


Remarca 38 : Reţinem faptul că la sfîrșitul ciclului fetch (M1), microprocesorul „„ştia” 
deja dacă saltul va fi efectuat sau nu. Dacă saltul urma să nu fie efectuat (cazul de față), 
citirea celor 2 octeți de adresă (ciclurile M2 şi M3), nu mai este necesară, instrucţiunea putînd 
fi executată prin dubla incrementare a contorului program PC, astfel încît el să indice 
adresa de început a instrucţiunii următoare. Astfel s-ar fi cîștigat timp — cel puţin 4 cicluri 
de tact ceea ce reprezintă 40%. Z80 nu procedează însă așa, preluînd această insuficiență 
de la predecesorul său microprocesorul 18080 — tocmai pentru a fi compatibil de sus în 
jos cu acesta. Insuficienţa a fost însă eliminată la implementarea instrucţiunilor de salt rela- 
tiv care execută un număr diferit de cicluri de tact pentru condiţia adevărată sau falsă, in- 
strucțiuni pe care 18080 nu le posedă. Vom vedea. 


Remarca 39 : instrucţiunile de salt condiţionat absolut, testează cei 4 indicatori de 
condiţie principali: S — semn, Z — zero, P/V — paritate/depășire şi Cy — transport. 
Pentru fiecare flag testat condiţia de salt se poate enunţa în 2 moduri: 

— salț dacă flagul este 1 

— salt dacă flagul este O 
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Rezultă cele 8 instrucţiuni amintite: 


JP NZ, adresă — jump if not zero  — salt dacă Z=0 
JP Z, adresă — jump if zero — salt dacă Z=1 
JP NC, adresă — jump if not carry  — salt dacă Cy=0 
JP C, adresă — jump if carry — salt dacă Cy=1 
JP PO, adresă — jump if parity odd — salt dacă P/V=0 
JP PE, adresă — jump if parity even — salt dacă P/V=1 
JP P, adresă — jump if plus — salt dacă S=0 
JP M, adresă = jump if minus — salt dacă S=1 


Continuăm execuția programului : 


Instrucţiunea „Set Carry Flag” acționează direct asupra indicatorului de tran- 
“port Cy, înscriind în el valoarea 1. Ea se codifică pe 1 octet și se execută în 
4 tacți procesor, | : 


SPEEU 
1 9 cc MC IC TRACE Fasr MU 


seat | CO: o | aa | 


lm.113 


1Y 9208 
ZE a EDO ei 


7OaE | 


D Sa-z22-— 


DEEE A00A-Z2 


Remarca 40: instrucţiunile SCF și CCF (Complement Carry Flag) sînt singurele 
instrucţiuni care permit manipularea directă a unui bit indicator de condiție. Ele acţionînd 
isupra unui bit individual, au fost incluse în clasa instrucţiunilor orientate pe bit (BITSR) 
Mături de BIT, SET și RES. 


RRA este una din cele 4 instrucțiuni de rotire a conținutului registrului 
A pe care le posedă și microprocesorul 18080. Z80 mai adaugă 70 de ins- 
trucțiuni de acest gen incluse de noi în clasa instrucțiunilor de rotire/depla 
sare ROT/SHIFT, 

Să urmărim execuţia instrucţiunii RRA (Rotate Right Accumulator), tact cu tact. 
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Începe ciclul fetch CM=1, T=10 


Codul citit 


bee "ua cc MC LE =i TRRCE FAST 
25R [NERA [7 1] 
7ees|con: tr |em:e1] 
291 
re 99| | SAR 
23909016 


ze 
şi 
| 
A.L 


z 


COMMAND 
CIRCUIT 


IFF1:8 
IFF2:0 
MOD :8 


Ax 


2T 220099 
i 
ATANLA 


Îm.114 
se depune în registrul instrucțiune IR (CM=1, = 


IC TRACE FAST 


COMMAND 
CIRCUIT 


IFF=:0 


1 
ia: 
Irm.115 
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La începutul celui de-al 4-lea tact al instrucţiunii se decodifică ; 


seegoPerrpeTeepr ere ere 
ES COP PIE TRAGE! FAST 


a 33) FE 93! [gis 


[zaa|£-aa| 


EI) case | 


Apoi conținutul registrului acumulator este transferat în ALU pentru a fi rotit: 
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: FL 
SPEED 
13 cc ME IE TRACE Fasr BA 


A0R ce. 
zaoe [esse lem:er] Ţ] 


E sa|c ea 
o oale ee 
oo 


MEMO 
1F| 


d 


SE 
3]3 
si ke 
2]8 


AT 
1 

IX 0999 
RE 
dă ReUIT 
BUZAK = ceea Fc 7ee7 | Zaza 
RESET IFF2:0 i 

MOD :8 
AE 7010 


Im. 117 


Rotate Right : rotirea se face la dreapta, prin „carry”, astfel încît bito al lui 


| A se transferă în Cy, 
[_] 


SPEE 


1-3 “CE MC IC TRACE FAST 


lm.118 
COMMAND 
CIRCUIT 
iar bitul Cy inițial ajunge în bit, al lui A. 
sragoi CE TUE TC TRACE Fagrliii 
e_ee|c ee 
o _eej|= ee! 
|H_eeji. ee! 
e'ee|c'ee| 
D'ee|='ee) 
CEC Im.119 
w_7e|z ea! 
R_1£|! ee 
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Remarca 41 : Acţiunea instrucţiunii este deci : 


Fig. 7.1. Rotirea „prin'” 
carry (la dreapta) 


7 0 eh 


Din păcate în lm.119 nu s-a „prins" ultima secvenţă grafică executată de VISIBLE Z80 
și astfel nu putem vedea că simulatorul execută într-adevăr corect instrucțiunea, flagul Cy 
fiind de fapt O la sfîrșit. Cine se îndoiește de asta n-are decît să se convingă rulînd sec- 
venţa de sus cu VISIBLE Z80. 


Acest tip de rotire (Rotate Left with Carry Accumulator) diferă puțin de 
cel precedent : rotirea nu se face „prin'” carry ci „cu” carry. 


Fig. 7.2. Rotirea „cu'” 


Z a— : carry (la stînga) 


În Im.120 care prezintă starea de fapt la sfîrșitul execuției instrucţiunii, 


redăm efectul : 
A=80, inițial se transformă în A=01j, bitz A mutîndu-se în bitoA. Totodată 


valoarea 1 a bit, A apare și în flagul Cy. 


Remarca 42 : Cele patru instrucţiuni de rotire RLCA, RRCA, RLA, RRA moștenite 
de la 18080 se regăsesc și în setul extins de instrucţiuni ROT/SHIFT proprii microproceso- 
rului Z80. Acolo ele se numesc: RLC A, RRC A, RL A și RR A. Efectul primar al aces- 
tora este identic cu cel al instrucțiunilor moștenite. Ele diferă însă ca structură (se codifică 
pe 2 octeți spre deosebire de primele care necesită doar un octet), timp de execuţie (8 
tacţi procesor față de 4) și prin efectele secundare : instrucțiunile noi ale lui Z80 poziţio- 
nează flagurile S$, Z în conformitate cu realitatea obținută după efectuarea lor, pe cînd cele 
moştenite nu fac acest lucru. Motiv pentru care am separat instrucțiunile de rotire RLCA, 
RRCA, RLA şi RRA, de clasa instrucțiunilor ROT/SHIFT, incluzîndu-le în clasa instrucțiu- 
nilor aritmetice/logice pe 8 bit AR/LOG-—8, ceea ce nu este prea departe de adevăr, dato- 
rită faptului că o rotire la dreapta sau la stînga poate însemna și o înmulţire respectiv o îm- 
părţire cu 2 a unui număr binar. 
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COMMAND 
CIRCUIT 


Această instrucțiune de salt condiționat relativ se codifică pe 2 octeți: 
primul este octetul de cod (384) iar cel de-al 2-lea un număr cu semn, exprimat 
în complementul față de 2, ce reprezintă deplasamentul saltului, față de valoarea 
instantanee a contorului program PC. Astfel instrucțiunea va ocupa în memorie 
adresele 7008, și 7009... 

Structura instrucţiunii, în limbaj de asamblare, este aceeași cu cel de la 
salturile condiţionate absolute : JR C, depl însemnînd „salt relativ dacă Cy=1". 

Să urmărim execuția instrucţiunii, în modul MC (ciclu mașină) al lui VISIBLE 

— Z80, știind-că saltul se va efectua, din moment ce Cy este înscris: 
În ciclul fetch M1 (CM=1,  T=4) am citit și interpretat codul instrucţiunii : 38. 
În cel de-al 2:lea ciclu mașină s-a citit deplasamentul 01 care a fost depus în 
registrul tampon T. (Im. 122) 

Reținem faptul «u PC conține deja adresa instrucţiunii următoare : 


Datorită faptului că saltul se va efectua (condiția testată s-a dovedit a fi 
adevărată) se negesită un ciclu mașină intern, de 5 tacți procesor pentru cal- 
ouiul adresei absolute de salt: 


PC = PC + depl. 
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Im. 124 


COD : 2801 . 


IE. TRACE FAST 


cc MC 


AD 


7203 


1m.122 
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Din lm.123, care fixează ultima „„mișcare"' a instrucţiunii, observăm că rezultatul 
adunării s-a generat în primă instanță în registrul dublu WZ, fiind apoi trans- 
ferat în PC. Saltul se face deci la 700B,, ocolind instrucțiunea de la 700A,,. 


ai cc MC IC TRACE FAST 


ADR ÎMNE:9R C.Q1 
7008 |COD: 2821 


=3 


Ein) 


COMMAND 


CIRCUIT IFF1:0 


IFFz:0 
MOD :8 


IN 
NM 
Mi 
MR! 

IG 
RD 
WR 
EI 
EU 
RE 
hi 


za 
pn 


lm.123 


Remarca 43 : Dacă condiţia de salt n-ar fi fost satisfăcută, atunci nici cel de-al 3-lea 
ciclu mașină M3, n-ar fi fost necesar, fiindcă PC indica deja adresa de început a instrucţiunii 
următoare (700A,,). Execuţia durează 12 tacţi procesor (4, 3, 5) dacă se efectuează saltul, 


și 7 tacţi procesor (4, 3) dacă nu. 


Remarca 44 : instrucțiunile de salt condiționat relativ nu testează decît 2 indicatori 
de condiţie, pe cei importanţi, totalul for fiind deci 4: 


JR NZ, deplasament — jump relative if not zero — Salt relativ dacă Z=0 

JR Z, deplasament — jump relative if zero — salt relativ dacă Z=1 

JR NC, deplasament — jump relative if not carry — salt relativ dacă Cy= 
=0 

JR C, deplasament — jump relative if carry — salt relativ dacă Cy= 
=1 


Remarca 45 : Plaja adreselor care se poate acoperi prin salturi relative este de 
[+4+127, —128] dacă se consideră ca punct de referință adresa de început a instrucţiunii care 
succede instrucțiunea de salt relativ. 

Considerînd adresa de început a instrucţiunii de salt ca punct de referință, plaja sal- 
turilor posibile devine [--129, —126]. 


Sărind deci peste instrucțiunea RST 08H vom continua călătoria la adresa 


7008, nu înainte de a șt: că instrucțiunile RST (8 la număr) sînt instrucțiuni de apel 
a unor subrutine locate la adrese fixe de memorie (0,84, 104, ..., 384). Adre- 
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sele fiind fixe, ele nu trebuie specificate sub forma a doi octeți în cîmpul instruc- 
ţiunii, ci adresarea se poate face implicit, în codul de operaţie. Reducînd numărul 
de octeți necesari de la 3 la 1, instrucțiunile RST devin foarte rapide, folosirea 
lor fiind recomandată la acceptarea unei cereri de întrerupere, unde răspunsul 
trebuie să fie cît mai prompt. 


Instrucţiunea tipică ROT/SHIFT are același efect primar (rotire la dreapta 
(right) „„prin'”' carry) ca și RRA, diferă doar obiectul, care de astă dată este 


registrul B. 
SPEgDPEEF Re PETE ET 
13 cc MC IC TRACE F 257 ANU 


“+ 


Primul ciclu fetch (lm.124) citește codul caracteristic al clasei ROT/SHIFT, CBu. 
Cel de-al doilea ciclu mașină (de asemenea fetch) citește codul propriu-zis (lm.125). 
Execuţia propriu-zisă a instrucţiunii, avînd loc într-un tact ascuns în ciclul mașină 
al instrucţiunii următoare (CM=XX, T=2) 

(lată-l pe camaradul nostru, acel plăpînd bit ,,1'', de care aminteam la începutul 
aventurii, apărînd în „viața” registrului B: bit,B=1) 


SRA este o instrucțiune de deplasare tipică pentru Z80. Semnificația mne- 
monicei alese (Shift Right Arithmetic) poate fi contestată, efectul în schimb nu : 
(vezi fig. 7.3). 
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speegoPEP Repere EEE 2002) 
15 cc! MC! IC WRACE FAST 


ADR |ÎMNE:RR E 
7008 |COD:CE18 


III Ed-zz2Z- 
DIERee 1004-32 


[ai 
SFEED Piti] 
12 cc ME IC TRACE FAST 


ADR ÎMNE:RF B DE 1sFP 
7aoe|CoD:Cp18 | ăRtău) 


19aanaaa 
HF 


2 
Fi 
0 2 


COMMAND 
CIRCUIT 


Im. 126 
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reg 
Fig. 7.3. Deplasarea arit- 


metică (la dreapta) 


Conţinutul registrului căutat este deplasat cu o poziție la dreapta : bitul 


cel mai puțin semnificativ este transferat în Cy iar cel mai semnificativ, rămîne 
neschimbat. 


S-o vedem și pe asta; 


CEE EEE FETE NERTEE FIE 
ce ACE FAST 


[m.127 


Același cod (CB) citit în primul ciclu fetch (lm.127) 


Se citeşte și octetul propriu-zis de cod (284), transferînd conținutul registrului 
B la intrarea în ALU. În lm.129, (CM=XX, T=2) bitul cel semnificativ al regis- 
trului B s-a dedublat (bit, =bit, =1), iar flagul carry a fost șters de către bit.B. 


Remarca 46 : Toate  înstrucţiunile de rotire/deplasare (RLC, RRC, RR, RL, SLA, 
SRA, SRL precum și cea „ascunsă de Zilog, dar descoperită de Szasz Detre și notată de 
noi SLH) pot opera pe conținutul oricărui registru simplu de uz general (B, C,D,E,H, 
L sau A) sau pe cel al oricărei celule de memorie adresată prin regiştri 


dubli privilegiați 
(mereu aceeași) HL, IX și IY. 


Cu instrucțiunea deja cunoscută pregătim un apel condiționat al subrutinei 
locate la adresa 7050, (lm.130). 


Condiţia fiind adevărată, saltul se va efectua. 
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ri 
(i 
(u 


IE 
ul 
O|I 


ȘI 


| 
3 
a 
E 
9 


Ea 
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Im.129 


Totul despre microprocesorul Z 80 vol. 1 și 2. 


Im.128 


I4= 


ag! ce LE= TRaCE FAST 


$305227 
300 22 


CIRCUIT 


CAI200 


Să urmărim apelul : 

Codul instrucţiunii (C4,) este preluat și „înțeles” în ciclul mașină M1 (lm.131). 
Urmează citirea celor 2 octeți de date, care reprezintă adresa de început a sub- 
rutinei apelate (7050,). Primul sosește, ca de obicei, octetul cel mai puțin sem- 
nificativ. El este depus în registrul tampon Z. (lm.132, CM=2, T=3). 

Apoi se citește şi octetul cel mai semnificativ și se plasează în W (lm.133, 
CM=3, 3) 

Dacă condiția de salt n-ar fi adevărată, execuția instrucţiunii s-ar termina aici, 
după 10 cicluri de tact (4,3,3), contorul program PC indicînd, chiar bine, adresa 
de început a următoarei instrucțiuni 7014, din programul principal. 

Știind că n-are încotro, saltul la subrutină trebuie efectuat, microprocesorul 
salvează pe stivă (la adresele 7DFF și 7DFE) conținutul curent al contorului pro- 
gram (PC=70144), pentru a se putea întoarce după terminarea subrutinei, în 
programul principal din care plecase. 

Se salvează prin cicluri WRITE mai întîi PChizn (lm.134), iar apoi PCiow 
(Im.135). 

Saltul la subrutină este declanșat în ultimul ciclu de tact a instrucţiunii, 
cînd WZ este copiat în PC (lm.135). 


Remarca 47 : Cîteva cuvinte despre subrutine : 

Dacă o secvență program poate fi folosită de mai multe ori pe parcursul elaborării 
unui program, atunci ea se va scrie o singură dată, sub forma unei subrutine. Astfel pro- 
gramul rezultat va fi mai scurt. Subrutina se distinge de restul secvenţelor de cod prin 
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1lm.131 


IC TRACE FAST 


5 cc MC 

II racti | 
LL] d 
25 


PL 
|| 


SPE 
1 


ti] 
L'99 
7 es 


IC TRACE FAST 
7050 


MC 
MNE: CALL NZ 
CIRCUIT 


cc 


011 |COD:C+59270 


= bit VA Ju — 
ZEr&OO& 22uldud 
-ZII-t3 MOLI&3 


SPEED 
ADR 
7 


Irn.132 
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able 


er 
pi - 


e 


t 
bn 


Im. 133 


7258 


7059 


IC TRACE FAST 


PI pi 
E | 
y i la 
y 4 y 2 
[=] * 
Douaia A 5 și Zizi5o a 


lm.134 
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1 [==] MC IC TRACE FAST 


ADR |MNE:CALL NZ.7050 | uitai] [| 
7011 |con:cesoza _______ | tăitaăa 


CIRCUIT 


Im.135 


faptul că se termină cu o instrucțiune de revenire (RET) în programul apelant. Adresa de 
memorie la care începe secvența instrucțiunilor ce formează subrutina, se numește adresă 
de apel sau punct de intrare. Dorind să-i acordăm un plus de generalitate, programatorul 
poate realiza subrutina cu mai multe puncte de intrare și eventual mai multe puncte de reve- 
nire. În programul principal, execuţia subrutinei se va prevedea incluzînd o instrucțiune 
de apel (CALL), la întîlnirea căreia execuția programului principal se va abandona, trecîn- 
du-se comanda în subrutină. După executarea ei, la întîlnirea unei instrucțiuni de revenire 
(RET), execuția codului revine în programul apelant la instrucțiunea imediat următoare 
celei de apel subrutină. O subrutină poate apela o altă subrutină, care și ea la rîndul ei 
poate apela subrutine, etc. 


Fenomenul se numește imbricare de subrutine. Datorită faptului că Z80 memorează 
adresa de revenire în programul apelant pe stiva din memoria RAM, numărul nivelelor de 
imbricări a subrutinelor poate fi practic nelimitat. (Teoretic el este oricum limitat*de dimen- 
siunea fizică a memoriei RAM, 64 kocteţi pentru microprocesorul Z80). 


Instrucţiunile de apel și revenire din subrutine (clasa CALL/RET) pot fi condiţio- 
nate sau necondiționate. Saltul la subrutină și înapoi se face totdeauna cu adrese absolute. 


Condiţiile de apel sau revenire se formulează la fel ca și în cazul instrucţiunilor de 
salt condiționat absolut, 


Li 


CALL  NZ, adresă RET NZ 
CALL Z, adresă RET ră 
CALL NC, adresă RET NC 
CALL C, adresă RET G 
CALL PO, adresă RET PO 
CALL PE, adresă RET PE 
CALL P, adresă RET P 
CALL M, adresă RET M 
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Remarca 48 : în afara avantajului prezentat (cel de-a scurta munca de programare și 
programul realizat), utilizarea subrutinelor oferă şi un altul, cu „,bătaie”' mai lungă. Creîns 
du-și rutine de uz general, care rezolvă anumite funcţii (sau probleme de programare) pro- 
gramatorul se poate ridica în gîndire, de la nivelul inferior al instrucţiunilor cod mașină, 
la unul mai elevat în care el tratează toată subrutina ca o funcție sau ca o instrucțiune 
microprocesor deja implementată. Tehnica de a substitui anumite secvenţe de instrucțiuni 
scrise în limbaj de asamblare cu o singură instrucțiune căreia ise atribuie, de către utiliza- 
tor, un nume cît mai sugestiv, se numeşte tehnica de folosire a macroinstrucţiunilor. Macro- 
instrucţiunile conferă unele avantaje suplimentare față de subrutine. Le vom prezenta în 
capitolul 1 al părţii a 3-a din prezenta carte. 


Trecem acum la execuția subrutinei de la adresa 7050 (în căutarea bitului 
pierdut). 


Această instrucţiune ROT/SHIFT rotește conținutul registrului B cu o poziție 
la stînga, „,„prin“' carry, conform figurii 7.4. 


Fig. 7.4. Rotirea „prin” 
carry (la stînga) 


—.— 


Starea finală a execuţiei instrucţiunii (lm.136) confirmă procedura ilustrată 
în fig. 7.4: înainte B=604, Cy=0 , 
după  B=80,4, Cy=1 


29 


COMMAND 
CIRCUIT 


IFF1:9 
IFF2:0 
MOD :8 


Pai “am =ă 


£NI20D EA-zIz-— 


a 
AIAMDA 
ui i 


!rn.136 


166 


i SPERE. 
Ș Şi acum „la dreap- S4EgPI ee ue PETITIE Tr AMI 
ta”, în C. Efectul in- 


strucțiunii este similar 
cu cel reprezentat în 
fig. 7.1]. 

O dată cu termina- 
rea „furtului de ciclu” 
(CM=XX%, 12) con: 


ss 


EEE 
statăm : C= 00; Cy= E "99 
=—1 iniţial se transformă n 
în (i == 80, Cy =0 e c'eaa| 
(1lm.137) D'99 
H'ee|'ee 
Lu 70| 
INT i 79, 
NEI [ez | DZ 
MREQ 
LORG 
RD 
ca CIRCUIT 
BUSRO 
RESET 
HâL 
RFsH 
Wa T 


SPEED POE TELE EI. 
13 CC ME IE TRACE FAST 


S-zz2z= 
X0OA-2Z 


COMMAND 
CIRCUIT 


<XI200 
PNENCC 


Im.138 
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Aici este începutul sfîrșitului. Tovarășul nostru de drum („,1') dispare încetul 
cu încetul. Deocamdată din registrul A: 


Remarca 49: instrucțiunea orientată pe bit RES permite ștergerea selectivă a ori- 
cărui bit din regiştri interni (B, C,D,E, H,L sau A) și din celule de memorie adresate 
prin (HL, IX+ IND sau IT-14ND). 

Instrucţiunile complementare SET (inscriu valoarea 1 pe- bitul selectat) completează 
numărul total al instrucţiunilor BIT, SET, RES la 240. 


Această instrucțiune cauzează o revenire necondiționată din subrutină în 
programul apelant, La întîlnirea ei contorul program PC este încărcat cu cei doi 
octeți, din vîrful stivei, realizindu-se astfel întoarcerea la adresa corectă, 

S-o urmărim în acțiune: 
singurul octet de cod (C9,) este citit și interpretat în ciclul fetch (lm.139). 


sPegOPEEE Re ee Er IEETEEE IT] 
1 cc MC IC TRACE FAST 


1m.139 
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În ciclurile mașină M2 și M3 se efectuează două citiri din memorie, octeții 
din virful stivei transferîndu-se direct în PC. 
Mai întîi octetul cel mai puțin semnificativ (14): 


spa DEE PRET TE TEZE EZE 
a E EEE pe IE TRACE E EE 


e'ee|c'ee | pizza 


H'ee|.'ee Im.140 
E (u Za] sa] 
N: ÎR_zE|! ee 
MREQ 
Lane 
R COMMAND 
WR 
CIRCUIT 
BUSRG IFF1:0 
BUSAK 
RESET IFF2:0 
H&L 
RFSH MOD :0 
WAIT 
Apoi cel mai semnificativ (70) : 
segolte ME IC TEaCE! Fasrălă 
ADR ÎMNE:RET [re_ 
7esejcon:cs | mătist| 
Im. 14) 


COMMAND 
CIRCUIT 
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Remarca 50 : instrucțiunile de revenire condiționată din subrutine (RET condiţie) 
folosesc un ciclu fetch de 5 tacți procesor. Folosind revenirea necondiționată (RET) același 


ciclu va dura 4 tacți procesor. 
Diferenţa își are originea în faptul că în cazul revenirii condiţionate testarea condiţiei 
impuse necesită un ciclu suplimentar de tact, 


Așadar, am revenit în programul apelant. 


Complementăm indicatorul de transport (Complement Carry Flag) (Im.142). 


1 5 cc ME Ic RACE Fas 0. i: 


AAA 1 
Fri] 
rul fa 


CIRCUIT 


[m.142 


Apoi ilustrăm apelul necondiționat al subrutinelor în modul IC. La sfîrşitul 
ciclului instrucțiune (lm.143) PC conţine deja adresa punctului de intrare în 
subrutină (PC = 70A0,). 


(Pe tine cititorule binevoitor te invităm să urmărești și evoluția indicatorului de 
stivă SP). 
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Din nou în deplasare: 


Ștergem penultimul bit de „1 (lm.144) 


spaga PPE PO TELE Ere 
13 cc MC IC TRACE Far AN 


COMMAND 
CIRCUIT 
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să ilustrăm o instrucțiune de revenire condiționată din subrutină : 


PE OPEEPREȚE PF eee EI. aaa 
i 5 ce MC IC TRACE FAST : 
ADR 

seuna| COD : SEARA | CH: 03 | 


COMMAND 
CIRCUIT 


IFF1:0 
IFF2:0 
MOD :0 


SAII00 SA-zz2Z-— 
DPHENCC S003=22 


Arma 


1m.145 


„Return if carry” ! Cy fiind 1, nu vom evita să ne întoarcem în programul 
apelant : lm.145. 


„O ultimă îmbrăţișare” : se șterge și ultimul bit de 1 (lm.146), 
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L/] 
i 
if 


o 
8 


H ee 
s'aa|c'ae 
H'eo|L'ea Im. 146 
isa Lu 7a|z 
NAT FR ZE I[] 
MA —— 
MREQ x o 
RES COMMAND 
SE CIRCUIT 
zi 
Gate £ 
După care, executînd instrucțiunea HALT 
RDB IA SEZA PE XP ZESRLEI3 
SPEED Ce Pe re TRACE Pas Ani 
[ii] 
Im. 147 
NMI 
MA 
MR 
RE COMMAND 
SR 


CIRCUIT 


ne vom opri și noi, și microprocesorul. 
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7:2. Sinteza clasei: BiTSR 


Clasa instrucțiunilor orientate pe bit numără 3x804+2—242 instrucțiuni. 
Mnemonicele aferente acestei clase sînt: BIT, SET, RES, SCF, CCF. 


Instrucţiunile de manipulare a indicatorului de transport (SCF și CCF) sînt 
moștenite de la microprocesorul 18080, celelalte 240 descrise cu mnemonicele 
BIT, SET, RES sînt noi, proprii microprocesorului Z80. În cazul lor numărul 
bitului afectat se specifică totdeauna implicit, pe cînd octetul „,purtător'' poate 
fi adresat: 


— implicit, cînd el se află într-un registru intern 
— indirect sau indexat, dacă el este locat în memorie. 


Instrucţiunile acestei clase le-am împărțit în 7 grupe funcționale. 


Încluzînd salturi absolute și relative, condiționate și necondiționate, clasa 
JUMP totalizează 18 instrucțiuni. 


Mnemonicele aferente sînt: JP, JR și DJNZ. 

În cazul instrucțiunilor de salt necondiționat și absolut, adresa de salt poate 
fi specificată și indirect (prin conținutul regiștrilor HL, IX sau IY), în celelaite 
cazuri, ea trebuie să fie referită explicit : absolut (pe 2 octeți) sau relativ (pe 
un octet). 


Instrucţiunile de apel și revenire din subrutine sînt descrise prin 3 mnemo- 
nice: CALL, RET și RST. 


Distingem în total 26 de instrucțiuni. 


La această clasă microprocesorul Z80 nu aduce nimic nou față de predece- 
sorul său microprocesorul 18080. 


Adresa de apel se poate specifica direct (CALL) sau, fiind fixă, implicit 
(RST). 

Adresa de revenire se specifică totdeauna indirect prin indicatorul de stivă SP. 

Toate instrucțiunile din clasă folosesc stiva din memoria RAM. 

Cele 26 de instrucțiuni au fost împărțite în 5 grupe funcționale. 
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În clasa ROT/SHIFT nu au fost incluse instrucțiunile RLCA, RRCA, RLA, 
RRA, comune cu microprocesorul 18080, datorită structurii și efectelor lor secun- 
dare diferite de cele ale clasei. Mnemonicele: RLC, RRC, RL, RR, SLA, SRA, 
SRL, RLD, și RRD reunesc în clasa ROT/SHIFT 72 de instrucțiuni. 

Spre deosebire de instrucțiunile de rotire ale microprocesorului 18080, cele 
noi, proprii lui Z80, poziţionează indicatorii de condiție. (În funcție de numărul 
care rezultă din acțiunea lor.) 

Cantitatea rotită/deplasată este octetul sau cifra (digitul). RLD și RRD rotesc 
cifrele hexazecimale (digiți) unei locații de memorie la stînga sau la dreapta prin 
digitul cel mai puțin semnificativ (bo—bs) al acumulatorului. 


Prin esența lor, instrucțiunile de intrare-ieșire sînt instrucțiuni de transfer. 
Datorită faptului că, pentru execuția lor se folosesc tehnici speciale, precum și 
datorită faptului că ele „,sparg”' granițele sistemului propriu-zis, comunicînd cu 


lumea externă, ele sînt tratate ca instrucțiuni aparte. Dacă numărul cererilor 
de intrare/ieșire este scăzut, atunci și frecvența de apariție probabilistică este 
redusă, ele putînd fi rezolvate eficace și în timp util de însăși „,creierul”' siste- 
mului (unitatea centrală). Dacă în schimb numărul lor depășește un anumit nivel, 
ele pot ridica probleme, fie datorită faptului că nu pot fi servite la timp, fie că 
obligă unitatea centrală să-și „„piardă” prea mult din timpul ei prețios, pentru 
rezolvarea acestor probleme doar aparent minore. 

Pe cînd în al doilea caz, — debarasarea unității centrale de probleme de 
I/E — este doar recomandabilă, „statul deoparte" devine obligatoriu atunci cînd 
ea nu poate realiza în timp util (real) cererile de I/E, pierzînd astfel nu numai 
informații prețioase, ci riscînd să piardă total contactul cu lumea externă. În 
asemenea situații poate apare blocarea sistemului, fenomen care se califică drept 
eroare fatală. Dacă blocajele unui sistem sînt frecvente, atunci el este pe bună 
dreptate apostrofat, spunîndu-se : „nu-i bun la nimic!” Pentru a evita această 
situație au fost elaborate subunități funcționale specializate pe probleme de intrare/ 
ieșire, care pot rezolva favorabil toate problemele de intrare/ieșire în mod auto- 
nom, fără a implica masiv unitatea centrală a sistemului. În sistemele mari dotate 
cu astfel de facilități — numite canale de intrare/ieșire — unitatea centrală luc- 
rează pe problemele sale și în timpul transformărilor de date efectuate de către 
canale, pe cînd în cele mici ea este de obicei suspendată în acest răstimp, uni- 
tatea specializată de intrare/ieșire preluînd comanda în sistem. 

Modul în care un sistem își rezolvă problemele de intrare/ieșire, poate fi un 
criteriu calitativ determinant, 

Fiind vorba de instrucțiuni de |/E ați realizat probabil deja, faptul că sistemul 
nostru rezolvă problemele „cu mînă proprie" adică cu participarea directă a uni- 
tății centrale. 
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Pe lîngă ciclurile mașină de bază (FETCH, READ, WRITE) instrucțiunile de 
intrare/ieșire efectuează și anumite cicluri mașină specifice, numite cicluri de 
intrare/ieșire. Pe cînd ciclurile de bază au ca trăsătură comună activarea semna- 
lului procesor MREQ, ciclurile de intrare/ieșire sînt concretizate de activarea 


semnalului IORQ (Input Output ReQuest). Pe parcursul lor, are loc transferul 
efectiv al unui octet între microprocesor și dispozitivul de intrare/ieșire selectat. 
Ele pot fi cicluri de intrare (IN), sau de ieșire (OUT). Microprocesorul Z80 
semnalează tipul ciclului mașină de |/E în curs, prin activarea (simultan cu IORQ) 
a unuia din semnalele de comandă RD (Read) sau WR (Write). 

Fiind deja familiarizați cu diagramele de timp, prezentăm ciclurile |/E în 
ordinea inversă față de cea folosită la ciclurile mașină de bază. Mai întîi reali- 
tatea (diagramele de timp) și doar apoi poveștile (aventură VISIBLE=Z80). 

Aidoma tuturor ciclurilor mașină ale microprocesorului Z80 și cele de intrare/ 
ieșire încep pe frontul crescător al semnalului de tact 8. 


Ciclul IN 


Fig. 8.1. Ciclul de citire (IN) de la un dispozitiv 


Așa cum reiese din fig. 8.1 ciclul IN începe cu activarea liniilor de adresă? 
pe liniile mai puțin semnificative A0— A7 apare adresa portului de citit, adresă 
care provine dintr-unul din regiștri interni ai microprocesorului. La începutul 
celui de-al doilea ciclu de tact (T2) se activează semnalele IORQ și RD speci- 
ficînd tipul ciclului mașină în curs: IN. 

Spre deosebire de ciclurile mașină de bază (cu acces la memorie) unde sem- 
nalele de comandă MREQ, RD, WR se activează pe frontul scăzător al primului 
tact din ciclu (T1), la ciclurile mașină de |/E, semnalele de comandă se generează 
cu o întîrziere de jumătate de tact procesor. Pentru a permite dispozitivelor de 
intrare/ieșire să se selecteze în timp util, microprocesorul inserează un ciclu de 
tact suplimentar Tw (vom vedea în cap. 9 ce înseamnă w — Wait). 

Considerînd că în 2,5 cicluri de tact dispozitivul de intrare apelat a reușit 
să-și plaseze datele pe magistrala de date (DO—D7), pe frontul scăzător al celui 
de-al patrulea ciclu de tact (T3) microprocesorul citește octetul de pe liniile de 
date, dezactivînd apoi semnalele de comandă RD și IORQ. Pe tot parcursul cic- 
lului IN semnalul WR este inactiv. 
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Ciclul OUT 

Mai întîi se generează adresa portului de ieșire (vezi fig. 8.2), pe AO—A7. 
După o jumătate de tact, procesorul plasează pe magistrala de date octetul de 
emis, Pe frontul crescător al ciclului de tact T2 se activează semnalele de comandă 
IORQ si WR. 

Din aceleași motive, amintite la IN, microprocesorul inserează un ciclu de 
tact suplimentar, urmînd să dezactiveze mai întîi semnalele de comandă (front 
scăzător în T3) iar apoi liniile de date. 

Semnalul RD este bineînțeles inactiv pe toată perioada ciclului OUT. 


Fig. 8.2. Ciclul de scriere (OUT) la un dispozitiv 


Reţinem că ambele cicluri mașină (IN și OUT) durează cel puțin 4 ciclu r 
de tact, 

Înainte de a efectua un ciclu mașină de |/E, microprocesorului trebuie să | 
se comunice informaţiile pe care el le are de vehiculat (adresă port, date de 
emis, etc.). 

Acest lucru se întîmplă în primele cicluri mașină ale instrucţiunii de I/E, așa cum 
vom vedea în aventura următoare. 


De astă dată drumul nostru va fi scurt: 


Instrucţiunea de ieșire cu adresare directă OUT (80),A transferă conținutul 
registrului A în dispozitivul (portul) de ieșire cu adresa 80H. Ea ocupă în memorie 
2 octeți. Primul octet este codul instrucţiunii, iar cel de-al 2-lea adresa portului 
de selectat. 

În primul ciclu mașină (Im.148) se citește și se interpretează codul instruc- 
țiunii : D3. 


178 INSTRUCŢ NI DE INI 


ce ME IC TRACE FAST 


LE 


Za 
=4 


"Sm 
92 


SII200 SA-zZ3z- 
PHPmCC 2 


Im. 149 
Reţinem ultima secvență din M1 :-conţinutul registrului A este depus în registrul 
tampon W (Im 149), 


Se _s] 


] PE 


COMMAND 
CIRCUIT 
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În cel de-al 2-lea ciclu maşină (READ) se citește octetul de adresă al portu- 
lui de ieșire (lm.150), 


MC IC TRACE FasrĂiă „ma 


Im. 150 
IFF1:0 
IFrF2:0 
MOD :8 

Im, 151 


a că COMMAND 
sus CIRCUIT 
pus 

BăLr 

RFSH 

WAIT 
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Conţinutul registrului transparent WZ constituie cuvîntul care se va plasa pe 
magistrala de adrese A0— A15 în timpul ciclului mașină OUT. Îl vom „filma” pe 


acesta cu încetinitorul (CC). 


Se activează liniile de adrese, plasînd pe ele conținutul amintit (lm.152) 


s 
7egonee PC IC RACE Far Al 


25 [MNE-DUT 50-A _____ [7:01] [58 
ace |eco:53sa __Jen:e3] Ţ) 


CIRCUIT 


IFF1:0 
IFF=2:0 


iar apol se activează semnalele de comandă IORQ, WR (lm.153). 
PL 


FL 
SF. 
ES Ce MC IC TRACE FAST 


AER 
7020 | Co0:D0389 CM:02 |] 


ERRRE 
ului 


e COMMAND 1Y 0090 
CIRCUIT SP 7:00 

BRUSRAG IFF1:8 

Susa: FC 7002 

RESET IFF2:0 

HALT | 

RF SH MOD :0 

da 


Im. 152 
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În fine, se emite conținutul registrului A pe magistrala de date (lm.154 și lm.155). 


SPE DEEE ere Sai 
EBD CEPE PC TRACE FAST : 


Zzzz= 
A-a2 
m 


SP 7E99 
FC 7002 


SIIA0N 


oi 3 CPU TIE TRACE FasTĂ ee 


iii; 
ADR 


COMMAND 


CIRCUIT 
IFF1:0 


IFF2=:0 
MOD :8 


Im. 155 


182 


Remarca 51 : Cei care au citit atent paragraful precedent și au urmărit în aceeași 
manieră imaginile de sus, au remarcat probabil două contradicții. 

1. În imaginile Im.153 şi lm.154 semnalele de comandă se activează înainte de emite- 
rea datelor, invers decît se întîmplă în realitate. Asta este, trebuie să recunoaștem, o eroare 
a VISIBLE—Z80. 

2. Ciclul OUT s-a terminat în 3 cicluri de tacți și nu în 4, cum afirmăm pe baza dia- 
gramelor de timp. În VISIBLE—Z80 am neglijat ciclul de tact suplimentar Tw. 


Remarca 52 : Spre deosebire de microprocesorul 18080, la care adresa portului de 
ieşire se repetă și pe liniile A8—A15, în cazul acestei instrucţiuni Z80 emite pe liniile 
superioare conținutul registrului A. 


Remarca 53 : Pentru a selecta un anumit port de ieșire (intrare), proiectantul (hard- 
ware) va trebui să decodifice folosind circuite logice combinaționale, sau alte tehnici, liniile 
de adresă A0O—A7. 


Remarca 54: Decodificind toată magistrala A0—A15 în ciclurile IN și OUT, avem 
posibilitatea de a selecta 21665536 dispozitive de intrare și tot atitea de ieșire. Chiar dacă 
numărul este total îluzoric, notăm acest plus de performanță a microprocesorului Z80 față 
de 080. 


Instrucţiunea de față citește conținutul portului de intrare a cărui adresă 
este cuprinsă în registrul C, și îl transferă în registrul D al microprocesorului. 
Instrucţiunea ocupă 2 octeți în memorie, ambii fiind octeți de cod. 

În primele două cicluri mașină, ambele FETCH, se citesc și se interpretează 
codurile. 

Prima dată EDu (lm.156): 
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ara oi ce ME TE RACE FAST E 
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AA 
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iar apoi EOuw : 


SPEE 
1 Şo 


| 


A _3+| 


ce ME IC TRACE FAST 


A 


| reia 


La sfîrșitul celui de-al doilea ciclu mașină, conținutul registrului B este trans- 


ferat în octetul cel mai semnificativ al bufferului de adresă AB. 


În cel de-al 3-lea ciclu mașină, ciclul IN, activitățile efectuate sînt : 
— conținutul registrului C se transferă pe liniile de adresă A0—A7 
— se citește portul astfel adresat, (adresa 15,4), încărcînd valoarea citită în 


registrul D (55,) 


— ca rezultat al operaţiei, se poziţionează indicatorii de condiţie a regis- 


trului F, în concordanță cu octetul citit. 


lm.158 reprezintă starea de fapte la terminarea instrucţiunii : CM=3, T=4. 
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spego PE Pepe eee 

Ego CE PC PE TRaCEI Pearl 
ADR 
7aa2 


REID ce e [EEEI-: 
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ROSII ee | 


INȚ 

NM [R_ts|! ee] 

MREQ |ix__ee9e | 

IEEE IX 9298 

hi” COMMAND 1Y aoaa 
CIRCUIT sp __7Eae | 

BUSRG Y IFF1:0 i să al ama 

See irra:0 | LES—722< 
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Remarca 55 : instrucțiunile IN și OUT pot folosi adresarea directă sau indirectă, 
„Via! registrul C. Cele cu adresare directă sînt preluate de la Intel, ele efectuînd transfe 
rul totdeauna prin registrul A. Necesarul lor de timp este 11 (4, 3, 4) tacți procesor. 

Instrucţiunile IN, OUT cu adresare indirectă folosesc conținutul registrului C pentru 
a specifica adresa perifericului dorit. Ele sînt proprii microprocesorului Z80, permiţind 
efectuarea transferului prin oricare registru intern : B, C, D, E, H, L sau A. În fine, așa cum 
am văzut, instrucțiunile IN din această grupă poziţionează și indicatorii de condiţie în 
concordanţă cu octetul citit. 

Durata instrucțiunilor de intrare/ieșire cu adresare indirectă este de 12(4, 4, 4) tacț 
procesor, 


Punem aici punct aventurii a 7-a, invitîndu-vă să parcurgeți sinteza clasei 
INJOUT pentru a cunoaște și instrucțiunile de transfer a blocurilor de date. 


Instrucţiunile de intrare (IN) și cele de ieșire (OUT) își împart frățește 
cele 24 de instrucțiuni ale clasei. Distingem cîte o instrucțiune cu adresare directă, 
moștenită de la 18080, «i cîte 7 instrucțiuni cu adresare indirectă a dispozitivului 
de intrare/ieșire, 
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Restul de 8 instrucțiuni și ele împărțite echitabil, sînt instrucțiuni de trans- 
fer a unor blocuri de date. 

Cu ajutorul acestor instrucțiuni pot fi transferați pînă la 256 octeți, dintr-un 
foc, între memorie și dispozitivul de intrare/ieșire ales. Aceasta este, datorită spo- 
rului de viteză, cu care se rezolvă multe probleme, facilitatea cea mai gustată 
de către hardiști, care se văd astfel scăpați în multe aplicații de proiectarea și 
realizarea unui subsistem de intrare/ieșire specializat. 


În acest din urmă capitol destinat prezentării microprocesorului Z80, vo m 
încerca să redăm tot ceea ce mai este necesar pentru ca cititorul fidel, să poată 
afirma cu sufletul împăcat, la sfirșitul primei părți a cărții, că știe totul despre 
funcționarea microprocesorului Z80. Pentru a-l putea și utiliza eficient, în e la- 
borarea unor produse bazate pe acest microprocesor, el va trebui să mai aibă 
puțină răbdare, parcurgînd cu același devotament și partea a 2-a a acestei cărți, 
învățind din studiul de caz prezentat, cum anume trebuie programat micropro- 
cesorul Z80, folosind cunoștințele deja acumulate privind funcționarea lui. 

Dar pînă atunci, să vedem ce ne-a mai rămas. 


Aminteam în cap. 3., la prezentarea semnalelor ds stare, că este d= dato ria 
unui conducător ca, după emiterea unei porunci, să arunce o privire asupra subo r- 
donaţilor lui, pentru a se convinge că cei chemaţi să ducă la îndeplinire ordi nul 
lui, sînt într-adevăr capabili să o facă în timp util. Știind că aceștia îi sînt par te- 
nerii, el n-are încotro, va trebui să mai aștepte în cazul în care constată că răs- 
punsul va întîrzia. Transpunînd fenomenul în lumea microprocesoarelor, se mnalul 
WAIT (așteaptă) va fi acela pe care unitatea de comandă a microprocesorului îl 
va interoga după emiterea fiecărei comenzi pentru a ști dacă ea a fost îndepli- 
nită cu succes, sau va trebui să mai aștepte. Dacă elementele componente ale 
sistemului sînt mai rapide decît o cere frecvența de tact a microprocesorului, 
atunci proiectantul poate uita de existența semnalului WAIT (legîndu-l printr-o 
rezistență de aproximativ 1 k 02 la 4+5V). În caz contrar, elementele mai lente 
vor trebui să detecteze faptul că sînt apelate, și să strige cu glas tare (a ctivînd 
semnalul WAIT), cerînd „stăpînului”' să mai aștepte. Detectînd o cerere de 
așteptare (WAIT), microprocesorul va amîna finalizarea ciclului mașină în curs, 
înserînd cîte un ciclu de tact de așteptare și verificînd de fiecare dată starea 
semnalului WAIT, pînă la dezactivarea acestuia. Astfel durata oricărui ciclu mașină 
care face apel la resursele hardware externe procesorului, se poate prelungi ori- 
cît de mult — cu un număr întreg de cicluri de tact —, chiar și la infinit. 

Trecînd peste această situație limită, absurdă în felul ei, constatăm că exis- 
tența semnalului WAIT permite sincronizarea procesorului oricît de rapid ar fi, 
cu elemente hardware mai lente, existente în sistem, creîndu-se astfel condiţiile 
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pentru conviețuirea pașnică a unei diversități mari de componente electronice, 
începînd cu memorii de ferită avînd un timp de acces de ordinul microsecundelor 
şi terminînd cu memorii semiconductoare bipolare, a căror timp de acces este 
de ordinul zecilor de nanosecunde. 

Cum orice activitate a microprocesorului începe și se termină pe frontul 
crescător al semnalului de tact , este lesne de înțeles că interogarea semnalului 
WAIT se va face pe frontul descrescător al aceluiași semnal. Astfel unitatea de 
comandă a microprocesorului va avea timp pentru a insera, în caz de nevoie, 
o stare de așteptare (WAIT), stare care de asemenea începe cu frontul crescător 
al lui 3. 

Vom ilustra, folosind diagrame de timp, efectul activării semnalului WAIT 
asupra fiecăruia din ciclurile mașină studiate pînă în prezent. 


Ciclul FETCH cu stări de așteptare. 

Semnalul WAIT este eșantionat pe frontul descrescător al celui de-al 2-lea 
ciclu de tact: (T2). Dacă el este activ în acel moment, atunci se va insera o stare 
de WAIT, cu durata egală cu perioada ciclului de tact. În mijlocul stării WAIT 
(frontul descrescător al tactului în Tw) microprocesorul verifică din nou linia 
WAIT. 

Dacă ea este activă și în acest moment, atunci se inserează o nouă stare de 
WAIT. După dispariția cererii de așteptare, execuția ciclului FETCH continuă 
cu ciclul de tact T3. (vezi figura 9.1). 


Cidu M1 


g 
ADRESE AA, 
MREA 

RD 
DATE Dy-Dy 
Mi 

WAIT 
RFSH 


Fig. 9.1. Ciclul M1 (FETCH) cu stări WAIT 


Reţinem că în afara momentelor de timp specificate, starea semnalului WAIT 
este neinteresantă, 

Ciclul READ cu stări WAIT. 

Prelucrarea eventualelor cereri de așteptare se face în aceeași manieră ca 


și în ciclul FETCH eșantionarea semnalului WAIT făcîndu-se pe frontul descres- 
cător al semnalului de tact în ciclul T2. (Vezi figura 9.2) 
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DATE DD, 


LL 7 II pestii ep, a „d E pepe | 0 ae 


Fig. 9.2. Ciclul de citire memorie (READ) cu stări WAIT 


Ciclul WRITE cu stări WAIT 
Ca și în cazurile precedente, interogarea semnalului WAIT se face pe fron- 


tul scăzător al ciclului de tact T2. Fenomenologia prezentată la ciclul FETCH se 
repetă și la ciclul WRITE (Vezi figura 9.3). 


Ea 
a aL! 


de a îi PE tacă 
DATE [eat O ie me e! 
Ti ARII giga, e” păi PRI pe ae „za, e urmă peace a 


Fig. 9.3. Ciclul de scriere memorie (WRITE) cu stări WAIT 


Ciclul IN cu stări WAIT 

Datorită faptului că în ciclurile mașină de intrare/ieșire semnalele de comandă 
IORQ și RD respectiv IORQ și WR se generază de abia pe frontul crescător 
al ciclului de tact T2, verificarea cererii de așteptare pe frontul descrescător al 
aceluiași ciclu de tact ar fi prematură : s-ar putea ca dispozitivul de |/E apelat 
să nu fi avut timp suficient pentru a-și formula răspunsul (să activeze semnalul 
WAIT). De aceea prima interogare se va face pe frontul scăzător al ciclului de 
așteptare Tw* pe care unitatea de comandă a microprocesorului Z80 o inserează 
automat în fiecare ciclu mașină IN și OUT. 

În figura 9.4 redăm istoria unui ciclu IN cu o singură stare WAIT impusă 
din exterior. 


Ciclul OUT cu stări WAIT. 

Din punctul de vedere al cererilor de așteptare, ciclul OUT nu diferă de 
ciclul IN (vezi figura 9.5) 

Dacă semnalul WAIT permite sincronizarea procesorului cu evenimente ex: 
prin mijloace hardware, instrucțiunea HALT oferă o posibilitate software c. 
scop asemănător. 
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social tei 


TORA 
DATE Dg-D7 


Fig. 9.5. Ciclul OUT cu o stare WAIT 


Instrucţiunea HALT este destinată sincronizării execuției unui program cu 
evenimente externe, care prin natura lor sînt mai puțin legate de funcționarea 
micreprocesorului, fiind din punctul de vedere al momentului de apariție, asin- 
crone față de acesta. Ca și în cazul așteptărilor hardware (WAIT), s-a pornit de 
la considerentul că microprocesorul este cel mai rapid: execuția programului 
ajunge la prelucrarea instrucţiunii de oprire HALT, înainte ca evenimentul extern 
să fi avut loc. După execuția instrucţiunii HALT microprocesorul „se oprește“, 
contorul program PC „înghețind” la adresa instrucţiunii imegiat următoare. La 
apariția evenimentului extern, sistemul generează o întrerupere (semnalul INT), 
care va scoate microprocesorul din starea „amorțită”' în care se afla după exe- 
cuția instrucţiunii HALT. 

După executarea rutinei de tratare a întreruperii, care într-un caz clasic de 
așteptare poate fi un simplu RET, microprocesorul continuă execuția programului 
din care fusese oprit, începînd cu instrucțiunea imediat următoare celei HALT. 

Știind că întreruperile pot fi inhibate pe cale software, pentru ca ieșirea 
din starea HALT să se poată face la apariţia cererii de întrerupere (INT) este 
necesar ca înainte de a intra în HALT microprocesorul să execute o instrucțiune 
El (Enable Interrupt), de validare a întreruperilor. (Cererea de întrerupere ne- 
mascabilă — NMI — va fi oricum acceptată, indiferent de starea validată sau 
inhibată a sistemului de întreruperi). 

Pentru cazul în care mult așteptatul eveniment nu mai are loc, dintr-un 
motiv sau altul, a fost prevăzută posibilitatea ca microprocesorul să poată fi scos 
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din starea oprită (HALT) și prin intermediul semnalului de ultimă instanță: 


RESET. 


Să urmărim cu ajutorul lui VISIBLE—Z80, într-o aventură de 12 imagini 
comportamentul microprocesorului în starea oprită (HALT) și abandonarea aces- 
tuia prin recepționarea semnalului RESET. 


Instrucţiunea HALT se codifică pe 1 octet (764), și execuţia ei durează 4 
tacți procesor, 


Începem cu CM=1;T=3. Cedul (76) este depus în IR (lm.159): 


SPEEDERTTPT PT ET Er PTT pp 
13 CC ME IC TRACE FAST 


20R 
zace [cocs [en:er| 


|[-zseți-es 
illw ee|z ee! 
NMI SIR 1s|i ce 
în a 


2000 
RE 
s-AFILA) 
ARE 
aa 
1 
DD - 
9 9 
7 
[9 
2 EX EX! 
ij 


. 
9 
d 


[m.159 


Se incrementează numărătorul adreselor de reîmprospătare R. (vă mai amintiți ?) 
După care instrucțiunea se decodifică (lm.161). 


Și odată cu asta microprocesorul „,se oprește” activînd semnalul HALT pentru 
a aduce la cunoștință celor din jur, faptul că a executat o instrucțiune HALT. 
Din același motiv, VISIBLE— Z80 înscrie în cîmpul MNE al colțului de comentarii 
mesajul „HALT STATE”, semnalînd starea HALT (lm.162). 
Dar ce vrea să însemne informaţia CM=1; T=1? Nu cumva, totuși? Privind 


m.163 bănuiala noastră se amplifică, căci semnalele M1, MREQ, şi RD sînt active, 


iar pe magistrala de date soseşte codul instrucţiunii de la adresa 70014 (E5y). 
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[A 
SPEED ERP PrU Rep or T e ere, F+L17] 
183 cc MC IC TRACE FAST 


ADR |MNE:HALT De 7ef 
7aaa |coo:76 | 


MEMO 
Si: 
Li 


COMMAND 
CIRCUIT 


IFF1:a 
IFF=:a 
MOL :8 


Im. 160 


[) 
SFEED SL 
1939 Cc ME IC TRACE FAST 


ADR ÎMNE:HALT De 7ehp” 
7aoa|con:7e ___________ |cm:et1) || 


| za] ee] 

pi 
pe 
EI SÎ cea 
1Y aa2a 


PC 7001 
(| 


Ilas _7a:s 


zz= 
=3z 
=s 
LU 


£2 
30 
LTIMTTTTț. 


Lil, 

IT] 
S-A FII:A) 
AR2 


Im,161 


COMMAND 


CIRCULT 


e 
i 
ră 


Im.162 


IC TRACE FAST 


MC 


cc 


ini: 


Im.163 
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Ba chiar mai mult, Apare și T3 și odată cu el ciclul refresh (Im. 164). 


IC TRACE FAST 


Im.164 


EEE za 
Cp L Pa RACE FAST 
DR 


e  —. >] 
e  —. >] 
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Să nu se fi oprit microprocesorul, după ce a și spus „,HALT”? Pare se că nu! 
Codul se depune în registrul instrucțiune pentru a fi interpretat, și se activează 
RFSH (lm.165). 

Ceva pare totuși dubios : în drum spre IR codul citit E5, s-a transformat în 00, 
care nu este altceva decît codul instrucţiunii NOP! 


Remarca 56 : Asta a fost. „„Oprit' în starea HALT microprocesorul continuă să exe- 
cute instrucțiuni din memorie, dar le modifică, forțînd apariţia codului instrucţiunii NOP 
(NO oPeration), care de fapt nu face nimic. V-aţi gîndit ce s-ar întîmpla cu memoria dina- 
mică încredințată ciclului refresh al microprocesorului, dacă acesta s-ar opri efectiv? Nici 
nu e bine să ne gîndim! Proiectanţii microprocesorului Z80 s-au gîndit din timp la acest 
aspect, scutindu-ne pe noi, utilizatorii de o grijă în plus, 


Așa stînd lucrurile. să vedem ce se mai întîmplă. 
Execuția se derulează așa cum știm (lm.165, lm.166). 
După terminarea instrucţiunii NOP, într-un singur ciclu fetch începe altă instruc- 
țiune (lm.168) care și ea va fi transformată în NOP, și așa mai departe. 
Dorind să ieșim din starea HALT, abandonînd NOP-urile infinite, apăsăm tasta R 
a calculatorului nostru. Observăm că VISIBLE—Z80 a acceptat dorința noastră, 
activînd semnalul de comandă RESET la unul din pinii de intrare, în stînga jos 
a imaginii (lm.169). 


1 5 cc MC = RACE FAST 


: 


—— 


T 
CIRCUI IFF1:0 


IFF2:09 
MOD :8 


Im.166 
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mile zu cc MC IC TRACE FAST 
ADR | MNE : 22) ate 00 
7ee2|coD: _____________|em:e+1| 


COMMAND 
CIRCUIT 


1 [== MC IC TRACE FAST 


ADR |MNE:LD SP.4<00 
aaa | COD: 210044 [cM:01 | 


CIRCUIT 
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Urmărind elementele transpuse în invers video, observăm că el și-a și făcut 
efectul : PC=0RR=0, 1=0, IFF1=IFF2=0 și- MOD=0, 

Așa cum era de așteptat, se execută saltul la adresa zero, unde începe exe- 
cuția instrucţiunii LD SP,4400 (lm.170). 7 

Terminăm prezentarea instrucţiunii HALT prezentîndu-vă diagramele de 
timp care redau ieșirea din starea HALT prin recepționarea unei cereri de între- 
rupere. 


ciclu HALT 


Fig. 9.6. leșirea din starea HALT 


Tot vorbind de întreruperi, ar fi cazul să le cunoaștem. 


Intreruperea nemascabilă a fost prevăzută pentru semnalarea apariției unui 
eveniment de importanță majoră, care necesită participarea neîntîrziată a proce- 
sorului ca rezolvarea lui. Evenimentul trebuind să fie tratat imediat, nu este admi- 
sibil la cererea lui să fie amînată sau desconsiderată datorită unei stări întîmplător 
inhibate ca sistemului de întrerupere. 


Ca și în cazul celorlalte întreruperi (cele mascabile) după executarea rutinei 
de tratare a întreruperii nemascabile, execuția programului poate reveni în cel 
abandonat, continuîndu-se de la instrucțiunea la care ea fusese întreruptă. 


Intreruperea nemascabilă, spuneam, se acceptă în orice condiţii, cu cea mai 
mare prioritate. Ea va cauza unsalt necondiționat la adresa 0066, după ce în 
prealabil se salvează contorul program PC pe stivă, pentru a se putea reveni 
la programul părăsit forțat, 


Vom prezenta în continuare modul în care decurge acceptarea unei cereri 
de întrerupere. 


Să considerăm un program în plină rulare, ajuns în CM=1, T=2 al instruc- 
țiunii EX DE,HL (lm.171). 


Observăm că sistemul de întrerupere este validat (IFF, =IFF,=—1) 

Apăsînd tasta „|” pe claviatura calculatorului nostru, simulăm apariția unei 
cereri de întreruperi. VISIBLE—Z80 confirmă acceptarea intenţiei noastre, acti- 
vînd semnalul de stare INT (Im.172) 
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IFF1:4 
1lm.171 


LE = 


«HL 


MC 


CIRCUIT 


(ni 


MNE:EX DE 
COD:EE 


[= 
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> a 

7] amar | 
: | 
alele 
31318 
alu [iu 


[73] [55-EsF 
EZITA 


PC 7081 
23 fi 


IFF1:1 
IFF2:1 


MC IC TRACE FAST 
MNE: EX DE.HL 


COD:EE 
COMMAND 


CIRCUIT 


cc 


SFEED 
13 
ADR 
7000 


35 -E%os a 


Microprocesorul aflîndu-se în mijlocul executării unei instrucțiuni, între- 


ruperea nu este încă acceptată. 
Acum apăsăm tasta „N” a calculatorului, pentru a genera o cerere de între- 
rupere nemascabilă. VISIBLE—Z80 ne confirmă și această intenție, activînd sem- 


nalul NMI (lm.173). 


ut 3 [= MC = TRE FAST 


ADR ÎMNE:EX DE.HL 
70020 |coD:Ee 
L:) 


Sagaoe a 
4'ea| 309391 


= 


F 


COMMAND 1Y  eoee 
CIRCUIT SP _7E00 


IFF1:1 
IFF2: 1 
MOD :a 


Ş 


Im.173 


Remarca 57. Cererea de întrerupere se acceptă totdeauna la sfîrșitul ciclului instruc- 
țiune, în curs de execuţie. 


Remarca 58 : Cererea de întrerupere nemascabilă este prioritară celei mascabile : dacă 
ele apar concomitent, cea care este acceptată prima dată este cea nemascabilă ; dacă cererea 
nemascabilă apare după acceptarea întreruperii mascabile, atunci ea va întrerupe execuţia 
rutinei de tratare a cererii mascabile, 
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Execuţia instrucţiunii în curs se termină în CM=1, T=4 (lm.174), 


, E 
Sg e age 


c MC IC TRACE FAST 


lm.174 


prin interschimbarea conținutului celor 2 regiștri dubli DE și HL. (lm.175). 


sPEgDPErr Pre Pere IP 
19 CE ani MC IC TRACE FAST 


ADR |MNE:EX DE.HL 
zooa|eoă:es [ema 


COMMAND 
„CIRCULT 


BUSRQ 
Ruset 
Aire [n.175 
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lar acum este acceptată cererea de întrerupere (lm.176). VISIBLE—Z80 ne con 
firmă și el intrarea într-un ciclu special, afișînd mesajul 1 „NONMASKABLE 
INTERRUPT” 


1 cc MC AG _ TRACE Paz Eh 


Im. 176 
COMMAND 
CIRCUIT 
1 ce MC IC TRACE Pr DU 
1m.177 


IFF1:4 
IFF2: + 
MOD :0 
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Urmărind în continuare evoluția microprocesorului, constatăm că deocam- 
dată se continuă ciclul fetch al instrucţiunii de la adresa 7001, (cod : 3E = LD A,n) 
Octetul citit se depune în bufferul de date (lm.178) 


Se incrementează contorul program (lm.179) 


SPEED 
43 cc MC IC TRACE FAST 


ADR |MNE:NONMASKABLE 
7001 |COD: INTERRUFT |CM:01 


EXCII 


Im, 179 
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De abia acum (CM=1, T=2) apare un element nou, distinct față de un fetch 
obișnuit : bistabilul primar de stare IFF, al sistemului de întrerupere se șterge, 
după ce în prealabil valoarea lui a fost copiată în bistabilul secundar IFF, : 


COMMAND 
CIRCUIT 


1rm.480 2 Ă | sai, 


Remarca 59 : Bistabilul secundar IFF, din sistemul de întrerupere este o celulă 
de memorie tampon, pentru salvarea stării sistemului de întreruperi. Starea, validată sau 
inhibată, a sistemului de întrerupere este determinată de valoarea bistabilului primar de stare 
IFF,. Știind că o întrerupere nemascabilă nu poate fi la rîndul ei întreruptă de către o între- 
rupere mascabilă, pe durata de execuţie a rutinei de tratare a întreruperii nemascabile, 
sistemului de întrerupere trebuie inhibat. După terminarea acestei rutine, este recomandabil 
să se refacă starea iniţială a sistemului de întrerupere la cea existentă înainte de apariţia 
NMI. 


lată de ce avem nevoie de un element de memorare a stării sistemului de întrerupere, 
rol preluat de IFF,. 


Remarca 60 : Refacerea stării sistemului de întrerupere se face prin copierea lui 
lui IFFo în IFF„, odată cu execuţia instrucţiunii de terminare RETN (RETurn from Non 
—  maskable interrupt). Amintim că folosirea instrucţiunii RETN nu este obligatorie, rutina 
de tratare a  întreruperii nemascabile putîndu-se termina și cu una din secvențele RET 
sau EI, RET. În primul caz sistemul de întreruperi rămîne inhibat, iar în cel: de-al doilea el 
va fi obligatoriu validat. Dezavantajul acestei soluții constă în faptul că se pierde valoarea 
programată a lui IFF,, ceeace în anumite situații poate fi deranjant. 


Urmărind VISIBLE—Z80 în continuare, ajungem la CM=1, T=—3. Paralel cu 


demararea unui ciclu refresh, codul este depus în registrul instrucțiune IR (lm.181, 
Im.182) 
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Se continuă pe făgașul obișnuit, incrementînd registrul R (lm.183) 


19 cc MC IC ACE FAST, 


ADR. |MNE: NONMASKABLE 
7001 |con: INTERRUPT |CM:01| 
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Acum am putea avea falsa impresie că apare o secvență eronată (lm.184) 
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Dar unitatea de comandă a microprocesorului nu greșește : rezultatul decodifi- 
cării codului citit — 3Eu în cazul de față — este ignorat, elementul apelat în 


continuare nefiind PC, ci SP! 
Încep ciclurile mașină destinate salvării adresei de întoarcere : (lm.185) 


spegoFerrpeț er peer ere ere 
4:57 .EC MC IC TRACE Far Bi 
2OR 
7091 |COD: INTERRUPT 


gaoaea.a 
855250 


CIRCUIT 


Im.185 


După o primă decrementare, SP este depus pe magistrala de adrese (Im.186) 
Se decrementează din nou SP (lm.187) 
lar apoi octetul cel mai semnificativ al PC (704) este înscris pe stivă (lm.188) 
Cel de-al doilea ciclu WRITE îl efectuăm în modul de lucru MC. (Im.189). 
La terminarea acestui ciclu mașină în contorul program PC apare adresa de salt 
(0066, ) 

În ultima imagine vedem începutul (CM=1, T==4) de execuţie a instrucţiunii 
locate la adresa 00664 (Im.190). 
Astfel am și ajuns la rutina de tratare a întreruperii nemascabile. Ce anume se : 
va întîmpla în această rutină rămîne la latitudinea totală a proiectantului de sis 


tem și a cititorului. 
Ajunși la sfîrșitul penultimei aventuri să facem o utlimă constatare : 


Remarca 61 : La acceptarea unei cereri de întrerupere nemascabile microprocesorul 
execută obligatoriu un salt la adresa 0066. 


207 


208 


[_ 
SP pa 1] 
1 ni: cc MC IC TRACE FAST 


ADR |MNE:NONMASKABLE IDE 3E|->y 
7981 |coo: INTERRUPT | : 


FARA 
ilelelele 


E 
s 


CIRCUIT 


|w_ee|z ee| 
ME R 25|! ee| 
Nasa IX eaee 
CR (3 


SPEEDRPEr PETE EEE 
ES ee Pe TE TRACE Fasr adli 


ADR |MNE:NONMASHABLE : 
7001 |coo: INTERRUPT |CM:02| 


i 
SPEE. 
13 cc MC IC TRACE Fag MA 


ADR |MNE NonmasnagLe [7 ez] 
7ea1 |con: INTERRUPT. |cM:02|” 


Du 


CRCIERI 


| 
SF __7DF 
Piz seeze Eeaeee 


IFF1:8 |[ 
Fe 7aaz 
'FF2:1 [ee __zacz | 


MOD :09 


COMMAND 
CIRCUIT 


Im.188 ” 


Aba! 
9 cc MC IC TRACE FAST 


ADR |MNE:NONMASKABLE 
7ea1 |can: INTERRUPT 


CITI EAI 


L) 

Şi În cre a Pasi 

MREQ IX 0909 

IGR& 

RD COMMAND 1 2992 
CIRCUIT 

EUSRQ 

BUSAK 

RESET 

HALT 

RF SH 

WAIT 


14 — Totul despre microprocesorul Z 80 vol. 1 și 2 209 


Pentru a sintetiza povestea, redăm diagramele de timp a ciclurilor mașină 
de acceptare a întreruperii nemascabile, atit cel obișnuit, cît și unul cu stări 


WAIT incluse (fig. 9.7 și fig. 9.8) 


|Uitimul ciclu mașină pi re Mb isi „ 
- Sly TU | Ta T3 T T5 TA 
LE 0 ge az ag e ie e po oaaac= * cca st aaa 
ADRESE Ag-Apr_ î_i e eX PE REFRESH 
MI BR 7 ci MI ZRI-E 2 ÎN pb 
MREG | 
RD ———— | 
: 
me HAS = 


Fig.9.7. Ciclul de acceptare f rai cereri de întrerupere nemascabie 
NMI 


Fig. 9.7. Ciclul de acceptare a unei cereri de întrerupere nemascabilă (NMI) 
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Ultimul citi Mapa ei ai 


Fig. 9.8. Ciclul de acceptare a unei cereri de întrerupere nemascabilă (NMI) cu stare WAIT 


Vă propunem să urmăriți o ultimă secvenţă: 


Secvențele menţionate în paranteze nu sînt instrucțiuni ci efectele unor 
intervenţii hardware ; cererea de acces la magistrale și cererea de întrerupere 
mascabilă. Dar să le luăm pe rînd: 


Enable lInterrupt (validează întreruperile) este o instrucțiune de comandă, 
Ea validează întreruperile mascabile înscriind valoarea „,1'' în bistabilele de stare 
a sistemului de întrerupere IFF, și IFF, (Interrupt Flip-Flop). 


Remarca 62 : După execuţia acestei instrucțiuni, întreruperile nu sînt încă acceptate! 
Fizic, sistemul de întrerupere devine validat doar după executarea următoarei instrucțiuni. 
Scopul acestei întîrzieri este acela, de a asigura în mod ferm posibilitatea de revenire dintr-o 
subrutină de tratare a întreruperilor. Secvența uzuală de terminare a unei rutine de tratare 
a întreruperilor mascabile este: 


EI 
RETI 
Dacă sistemul de întreruperi s-ar valida imediat după execuția instrucţiunii EI, atunci o 


cerere de întrerupere deja „formulată”, ar putea întrerupe rutina în curs, fără să se fi 
făcut revenirea din ea. Dacă acest fenomen s-ar repeta des efectul ar putea fi o supra- 
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încărcare a stivei riscîndu-se depășirea zonei alocate pentru ea. Efectele unui asemenea 
fenomen ar putea fi imprevizibile. Instrucţiunea opusă, cea de inhibare pe cale software 
a sistemului de întreruperi, se numeşte DI (Disable Interrupt — inhibă întreruperea). 


SPEGDPEEP Pere erTrre rr 
4" ce MC IC TRACE Pas A 


za 


2a009e1 e 
aaaeaa1ă 
| Să 

Lc.) 


ea LP_97 UE 


Astfel se programează cel mai complex (și performant) mod de întrerupere 
al microprocesorului Z80. 


Remarca 63 : Cele 3 moduri de întrerupere IM 0, IM1 și IM 2 diferă esențial în ceea 
ce privește: tehnicile pe care le folosesc, 

În modul 0, dispozitivul de intrare/ieșire care a solicitat întreruperea, va trebui să 
furnizeze în ciclul de acceptare a întreruperii, codul unei instrucțiuni. Această instrucțiune 
va fi, aşa cum probabil vă imaginaţi, o instrucțiune de apel a unei subrutine. (Nu va fi 
instrucțiunea de salt, căci trebuie salvat conținutul contorului program PC). 

De cele mai multe ori proiectanţii preferă instrucțiunile RST (ReSTart) fiindcă ele sînt 
codificate pe un octet. Dacă se folosește o instrucțiune de tip CALL, atunci dispozitivul 
1/E întrerupător va trebui să furnizeze 3 octeți, îngreunînd sarcina proiectantului de hardware. 
Folosind instrucțiunea RST saltul se va face la una din adresele (0, 8, 10H,...,38H). Deza- 
vantajul acestui tip de apel este că rutinele vor trebui să fie foarte scurte (8 byte), sau 
execuţia lor se va lungi cu o “instrucțiune de salt suplimentară. Dacă se generează codul 
instrucţiunii CALL, atunci devine accesibilă orice adresă de memorie, dar apare dezavanta- 
jul amintit. Modul 0 este echivalat cu unicul mod de întrerupere a procesorului 18080. 

În modul 1, Z80 execută automat o instrucțiune RST 38H. Acest mod se recomandă 
a fi folosit în sistemele cu o singură sursă de întrerupere. 

În modul 2, întreruperea este vectorizată. Folosind modul 2, în ciclul de acceptare a 
unei întreruperi, perifericul apelant va pune la dispoziția unității centrale un octet de adresă, 
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care împreună cu conţinutul registrului | tormează o adresă de 16 bit (octetul din | este 
cel mai semnificativ). Începînd cu această adresă se citesc doi octeți, care reprezintă adresa 
de început a rutinei de tratare a întreruperii solicitate. Modul 2 se recomandă a fi folosit 
în sisteme cu întreruperi multiple. Prin tehnica prezentată, microprocesorul este scutit de 
operaţia de identificare a dispozitivului care a solicitat întreruperea, saltul efectuîndu-se fără 
căutări, direct în rutina aferentă acestuia. Tehnica de adresare indirectă „„via'' memorie 
permite construirea unei tabele de salturi într-o pagină adresată de registrul |, conferind 
astfel software-ului eficiență și eleganță. Circuitelor integrate LSI din familia microprocesoru- 
lui Z80 (SIO, PIO, CTC, DART, etc.) li se poate programa octetul de adresă pe care ele 
îl vor reda în procesul de acceptare a întreruperii. 


Instrucţiunile IM (Interrupt Mode) se codifică pe 2 octeți, primul fiind EDy, 
și se execută în 8 (4,4) cicluri de tact (lm.192 și lm.193). 


[. 


PERFOPOIETET Pe 10] 2] 
nt ai Şi , 1E TRACE FAST = 


Pia 
î 
5 se|e'e| pă 


[oo |e-aa| | 


lm.192 


(O ultimă secvență din IM 2) 

Continuăm incursiunea în lumea instrucțiunilor de comandă și a ciclurilor 
mașină speciale, cu această banală instrucțiune de transfer, nu de dragul unei 
diversiuni, ci pentru a vă prezenta raportul de priorităte a celor 2 „cereri'' enun- 
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Piti] 78| 
1 cc MC IC TRACE FAST 


ADR ȚINEA 2 [us 
700: 


hal 


= i 


Im. 193 


țate în titlul paragrafului : cererea de cedare a magistralelor (BUSRQ) și cea de 
întrerupere (INT). 
Așadar nimic nou în primele 2 cicluri de tact (Im.194, Im. 195) 


â | 
SPEE 
AEO CC PMC IC RACE! FAST ll 

os _sE 7 


ADR ÎMNE:LD A.B 
70023|coo:7s 


Şsese 
Ea d n ae |_ee| 
[s2a|2ae) 
REED i AI Im. 194 
AT asfel 
za 
38 


CIRCUIT 
BUSFRO IFF1:1 = = 
pozat 2) dale 
RESET IFF2: 1 
HALT 
| MR :e 


214 


fie 
NEEEEEBER 


E 


IC TRACE FAST 


i) 


Im.195 


MC 


3 cc 
MNE:LD 4.8 . 


SF! 
1 
ADR 
7022 
HI G 
[] 


Vom apăsa acum litera „„|”, pentru a simula o cerere de întrerupere (lm.196). 


[73] (55 75F7 
EEII 


IC TRACE FAST 


MC 


cc 


(hui: 


MNE:LD 4 


ADR 
7003 


Im. 196 
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Cererea a ajuns la nivelul procesorului (INT — activat), iar sistemul de întreruperi 
este validat (IFF,=1FF-=1). 

Tastînd „B”, formulăm și o cerere de acces la magistrale, luată în conside- 
rare de VISIBLE—Z80 prin activarea semnalului BUSRQ (lm.197) 


[3 | 
[522588 == | 
= ESeaie 


| |eaca 
îm 


CIRCUIT 


PC _ 7294 


lm.197 


Execuția instrucţiunii în curs (LD A,B) continuă nestingherit, ea finalizîndu-se 
(Im.198). 

În secvența următoare, semnalul BUSAK (acceptarea cererii de magistrale — 
BUS AcKnowledge) se activează, microprocesorul acceptînd să fie suspendat. 
Magistralele de adrese și date sînt trecute în starea de înaltă impedanță, iar sem- 
nalele de comandă sînt și ele în tristate (MREQ, IORQ, RD și WR) sau inactive 
(M1, RFSH şi HALT). Magistralele fiind cedate, s-au creat condiţiile pentru ca 
o altă componentă de sistem să preia comanda, spre a efectua un acces direct 
la magistrală, de exemplu. 


Remarca 64: semnalul BUSRQ are o prioritate mai mare decit cererile de întreru- 
peri (INT și NMI). 


Remarca 65 :: Cererile de acces la magistrală se acceptă. la sfîrșitu! oricărui ciclu mașină 
(rezultă că microprocesorul aflat în starea WAIT — ciclul mașină neterminat — nu poate 
fi suspendat), 
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= 
SES cc MC IC TRACE FAST 


ADR CEEZI==, 
7003 |cob:72 leM:01| 
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EX ZI CICI 5 
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] 


[ 
E sn 
jE'ee! 


COMMAND 
CIRCUIT 


IFF1:1 
IFF2:1 
MAR :e 


Im.198 


A 
A 


oi PE Pe RACE Pas DA 
ADR :LD A.B Tr: xI[0oe 7sP 


U 
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HR 
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e 
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Im. 199 
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Apăsînd încă o dată tasta „B”, cererea de magistrale se anulează. Procesorul 
își reia activitatea, iar noi ajungem la ultima etapă a călătoriei noastre, mediată 
de VISIBLE— Z80 ; ciclul de acceptare a întreruperii mascabile în Modul 2. (Însuși 
numărul fotografiei, Im.200, semnalează importanţa acestui ultim asalt). 


1 5 cc MC L= TRaCE FAST 
ADR 
7004 |COD: INTERRUPT 


Im. 200 


„MASKABLE INTERRUPT” este mesajul emis de VISIBLE—Z80. S-a activat MI. 
Se inhibă automat sistemul de întrerupere : IFF, =IFF,=0 (lm.201). 

Se activează și IORQ solicitînd perifericului apelant să cedeze octetul de 
identificare (lm.202). 


Remarca 66 : Activarea simultană a semnalelor M1 și IORQ este „semnalul”” hard- 
Ware, prin care microprocesorul Z80 confirmă acceptarea unei întreruperi. Inversîndu-le și 
trecîndu-le printr-o poartă SI proiectantul obține un semnal de tipul INTA (INTerrupt 
Acknowledge), 


lar acum, celui care a solicitat întreruperea, (am fost chiar noi) VISIBLE—Z80 
îi va cere vectorul de întrerupere, emițînd mesajul "INTERRUPT VECTOR?" 
Să răspundem cu 20. 
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ACE ere 


MC - IC 
MNE : MASKABLE 


= = 


1 
ADR 
7084 


INTERRUPT 


COD: 


Im. 201 


IC TRACE FAST 


MC 
MNE : MASKABLE 
INTERRUPT 


SR EŞDI ce 


024 | COD: 


ADR 
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a 
sad 
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Im. 202 
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Valoarea citită se transferă în registrul instrucțiune IR, efectuîndu-se totodată 
ciclul de refresh caracteristic secvenţei : CM=1, T=3 (Im. 203, Im. 204). 
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SREgorEErPr Er Pee ACE Fag Bu de 


CE 
4 i 
ADR 
7004 


COMMAND 
CIRCUIT 


FEED 
SHE goreErPr ue TE TRACE Fag Al 


ADR: |MNE: MASKABLE 
7204 


COMMAND 
CIRCUIT 


Im. 203 


Im, 204 


După incrementarea registrului de refresh R, urmează o decodificare falsă : 
(Im. 205, Im. 206). 


SPE = p. 1] 


1 CE ME IE TRACE FAST 
ADR 
7024 


MNE:MASKABLE T :04| 


a_za] 99geoaa 
A'9a| 009915 
LU Li] 
] A.L.U. D'99|E'29 Im. 205 
NMI | I_7s| 
MA E 
RD COMMAND 
WR 
CIRCUIT 
EUSRR 
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RESET 
HaLT 
scie E ME 1E TRACE Fay DAU 
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ş 


200 EA 
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Urmează generarea vectorului complet, pe 16 bit: 
registrul de întrerupere | se transferă în registrul tampon W (Im. 207), 


SPEED 
13 cc MC IC TRACE Far DA 


ADR |MNE:MASKABLE ___ |T 
7004|COD: INTERRUPT | 


E za! 
ERCTICICZI 
Hoo. ee 
saa|e-aa] 
EXT CAII 
n:oel_'oe! 


LE "CE |r 


Im. 207 


nt COMMAND 
ciRcuiT [se cea | 
BUSRA ri:0 || —E00 
Roset PC 7004 
RESE IFF2:0 
HALT ŢI 
ea men :2 
PE 7004 
si vectorul citit de la periferic (20), se transferă din IR în Z (Im. 208). 
SPEED CEPE PE RACE! Fagr il! 


ADR ÎMNE:MASKABLE 
“aa |COD: INTERRUPT 


AA af 


o[eȚz[9 
8|8|s|5|; 


I 
[-] 
(- 


CIRCUIT 
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Urmează două cicluri WRITE (M2 și M3, în care se salvează pe stivă valoarea 
curentă a contorului program: PC (Im. 209 — Im. 213). Fără comentarii: 


IC TRACE FAST 


ss 20F7 
ie TEI: Ta RI CITI 


228291 
0090ea192 


L 
2_2a] 


COMMAND 
CIRCUIT 


Im. 209 


1 ce MC IC TRACE FAST 


eee MNE : MASKABLE 20 Pr 


js COD: INTERRUPT eee 3 


aa] | 


[e zaȚe aa] 
e see se 


RESET IFF2:0 
PS MOD :2 
valT 


Im, 210 
223 
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SPEED Sani 
15 cc MC IC TRACE FAST 


ADR |MNE:MASKABLE 
7084 |C0D: INTERRUPT 


Im.211 


SFEEDF pu TT] 
15 cc ME IC TRACE FAST 


ADR |MNE:MASKABLE 
7084 |COD: INTERRUPT 
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BUZA 
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Im. 212 


sPEgDEEEP Pepe Terre iti] 
1 $ cc Mc IC TRACE FAST 

ADR ÎMNE:MASKABLE | iat! 
7004 |COD: INTERRUPT 


IN 
NM 
Mi 
MR 
10 
RD COMMAND 
WR 
CIRCUIT 
BU 
EU 
RE 
HA 
RE 
Wa 


Remarca 67: „Obosit şi el", VISIBLE—Z80 a omis prima decrementare a indica- 
torului de stivă SP. De aceea el a salvat PC-ul la adresele 7E00 și 7O0FF în loc de 7DFF și 
7DFE, 


Și acum „ultimum ultimorum”: 


Folosind vectorul de 16 bit — 75204 — constituit, se efectuează două 
cicluri READ, citindu-se adresa de început a subrutinei de tratare a întreruperii 
„noastre” (Im. 214 — Im. 216). 
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În M4 se citește octetul cel mai puțin semnificativ: E5u 
[J pi] 


cc MC LE = FAST “ 
c5-s2F 
7eo«|cos:_inreasue? __Jem:e2] 7] 


Im. 214 
lar în M5 octetul cel mai semnificativ : 00 


SH ED cc MC LE =3 TRACE FAST 


ee 

LOR 

GR : COMMAND 
CIRCUIT 

& 

= 

ă 

ses 

Wa! 
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Adresa completă 00E5, se depune în PC și astfel se efectuează saltul dorit. 
aaa! 


ACE FAST 


shi 
[| 


slslelels 
e 
e 


CIRCUIT 


Im. 216 


Ultima imagine Im. 217, nu face mai mult decît să confirme SOSIREA. 


PEgoI ce TME TIC RACE FAST : 


pp 
Ea 


A 


ua 
+ 


SDIA0D EX-—z2 
pPuhă 30 
AMP: 


în 
29 


> 
Â 
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Terminăm aventurile noastre, revenind la realitate. Vă prezentăm diagramele 


de timp pentru tot ce ne-a mai rămas: BUSRQ/BUSAK și INT 


Oricare ticiu masină _____„|Magistrale eliberate 


î..- 
BUSRG 


BUSAK 


Ag- Ars 
Dg- D7 
REG, RO. 
i 
Fig. 9.9. Ciclul de cedare a magistralelor (BUSRQ/BUSAK) 


Ultimul ciclu mașină 
al unei instructiuni 


Fig. 9.11. Ciclul de acceptare a unei cereri de întrerupere (INT) cu o stare WAIT 
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Instrucţiunile HALT, 1MO, 1M1, 1M2, EI, DI, RETN, RETI și NOP le-am 
considerat instrucțiuni de comandă, grupîndu-le într-o clasă separată SYS. 

Găsiţi în paragraful E.14. descrierea acestor ultime 9 instrucțiuni ale micro- 
procesorului Z80. 

"Odpacznij po biegu'' (odihneștete după goană) spunea Wladyslaw Terl ecki 
în titlul cărții sale. Așa vom face și noi. 


tabela G.2 Lista alfabetică a instrucţiunilor ascunse 


NR. cop MNEMONI CA FLAG NR. NR. TIMP COMENTARII 
CRT SZ H PNC CIC  TACTI 2.5M 
1 DD 8c ADC A,XH LIXIXVO! 2 8 (4,4) a,2 
2 DD 80 _ADC A,XL 1IXIXVO! 2 8 (4,4) 3,2 
3 FD 8c ADC  A,YH VIXIXVO! 2 8 (4,4) 3.2 
4 Fo 8n ADC A,YL VIXIXVO! 2 8 (4,4) 3,2 
5 Dn 84 ADD A,XH VIXIXVO! 2 8 (4,4) 3,2 
6 Dn 85 ADD A,XL VIXIXVO! 2 8 (4,4) 3;2 
7 FD 84 ADD A,YH VIXIXVO! 2 8 (4,4) 3,2 
8 Fo 85 ADD A,YL 1IXIXVO! 2 8 (4,4) 3,2 
9 DD A4 AND XH 11X1XPO0O 2 8 (4,4) 3,2 
10 DD A5 AND XL 1IX1XPO0O 2 8 (4,4) 3,2 
11 FD A4 AND YH 1!IX1XPO0O 2 8 (4,4) 3,2 
12 FD A5 AND YL 1IX1XPO0O 2 8 (4,4) 3,2 
13 DD BC CP  XH VIXIXVI! 2 8 (4,4) 3,2 
14 DD BD cp XI VIXIXVI! 2 8 (4,4) 3,2 
15 FD BC CP YH VIXIXVI! 2 8 (4,4) 3,2 
16 FD BD CP  YL VIXIXVI!I 2 8 (4,4) 3,2 
17 DD 25 DEC XH VIXIXVI. 2 8 (4,4) 3,2 
18 DD 20 DEC XL VIXIXVI. 2 8 (4,4) 3,2 
19 FD 25 DEC YH 1IXIXVI. 2 8 (4,4) a;2 
20 FD 20 DEC YL VIXIXVI. 2 8 (4,4) 3,2 
21 FD 24 INC XH 1IXIXVO. 2 8 (4,4) 3,2 
22 DD 2c INC XL 1IXIXVO. 2 8 (4,4) 3,2 
23 FD 24 INC _YH MIXIXVO. 2 8 (4,4) 3,2 
24 FD 2c INC YL 1IXIXVO. 2 8 (4,4) a,2 
25 DD 67 LD O XH,A sa Xaooa a Dau Bi (4-A) 3,2 
26 DD 60 LD  XH,B a 2 Ba 44.4) 3,2 
27 DD 61 LD SHE PERNE IER ca aaa 3 ti Ay 3,2 
28 00 62 LD O XH,D i A "API i ele ME EP 3,2 
29 DD 63 LD O XH,E Ar 205 atit Lat e dei aa Ip) 3,2 
30 DD 6&F LD O XL,A E CX ai DR tA,4) 3,2 
31 DD 68 LD  XL,B NNE e a AA) 3,2 
32 00 69 LD  XL,C ca DR 04) 3,2 
33 DD 6A LD  XL,D E DER TD ca) 3,2 
34 DD 68 LD  XL,E stea aa 8 CAAD) 3,2 
35 FD 67 LD O YH,A AR 0, ARE ae e vi 3,2 
36 FD 60 LD  YH,B dat Mea 2 3 04 3,2 
37 FD 61 LD Vise seem 9 3 345 3,2 
38 FD 62 LD  YH,D eX Xau 3 8 RA) 3,2 
39 FD 63 LD  YH,E sleau 2 904) 3,2 
40 FD &F LD  YL,A i Ma 3 48 049 3,2 
41 FD 68 LD  YL,B e tic e 2 3 404) 3,2 
42 Fan 69 LD  YL,c voleMaae 2. 8 (4,8) 3.2 
43 FD 6A LD  YL,D stea aice 2 9 CA Ă) 3,2 
44 FD 6B LĂ  YL,E Na IP CAM 42 
45 00 7c LD  A,XH edita e aia De BCA) $,2 
46 Do aa LD  B,XH IA Mea 2 8 4454) 3,2 
47 DD ac LD  C,XH > aaa E. Di 04,83 3,2 
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NR. COD MNEMONICA FLAG NR. NR. TIMP COMENTARII 


CRT SzZ H PNC CIC TACTI 2.5M 
48 DD 54 LD D,XH ..X.X... 2 8 (4,4) 3,2 
49 DD Sc LD E,XH ..X.X... 2 8 (4,4) 3,2 
50 DD 70 LD A,XL ..Xe XX... 2 8 (4,4) 3,2 
51 DD 45 LD B,XL ..X.X... 2 8 (4,4) 3,2 
52 DD 40 LD C,XL ..X.X... 2 8 (4,4) 3,2 
53 DD 55 LD D,XL ..X.X... 2 8 (4,4) 3,2 
54 DD 50 LD E,XL ..X.X... 2 8 (4,4) 3,2 
55 FD 7C LD A.YH ..X.X... 2 8 (4,4) 3,2 
56 FD 44 LD B,YH ..X.X... 2 8 (4,4) 3,2 
57 FD 4C LD C,YH ..X.X... 2 8 (4,4) 3,2 
58 FD 54 LD D,YH ..X.X... 2 8 (4,4) 3,2 
59 FD Sc LD E,YH ..X.X... 2 8 (4,4) 3,2 
60 FD 70 LD A,YL ..X.X... 2 8 (4,4) 3,2 
61 FD 45 LD B,YL .. XX... 2 8 (4,4) 3,2 
62 FD 40 LD C,YL ..X.X... 2 8 (4,4) 3,2 
63 FD 55 LD D,YL ..X.X... 2 8 (4,4) 3,2 
64 FD SD LD E,YL seXoX e. 2 8 (4,4) 3,2 
65 DD 26 20 LD XH,N ..X.X... 3 11 (4,4,3) 4,4 
66 DD 2E 20 LD XL,N ..X.X.... 3 11 (4,4,3) 4,4 
67 FD 26 20 LD YH,N ..X.X... 3 11 (4,4,3) 4,4 
68 FD 2E 20 LD YL,N ..X.X... 3 Îi (4,4,3) 4,4 
69 DD 84 OR XH 11X0XPO0 2 8 (4,4) 3,2 
70 DD BS5 OR XL 11X0XPO0 2 8 (4,4) 3,2 
71 FD 84 OR YH 11X0XPO00 2 8 (4,4) 3,2 
72 FD B5 OR YL 11X0XPO0 2 8 (4,4) 3,2 
73 DD 9c SBC  XH,A VIXIXVi! 2 8 (4,4) 3,2 
74 DD 9D SBC  XL,A VIXIXVi! 2 8 (4,4) 3,2 
75 FD 9c SBC  YH,A MIXIXVI! 2 8 (4,4) 3,2 
76 FD 90 SBC YL,A MIXIXVI! 2 8 (4,4) 3,2 
77 CB 37 SLH A 11X0XPO! 2 8 (4,4) 3,2 
78 CB 30 SLH B 11X0XPO! 2 9 (4,4) 3,2 
79 CB 31 SLH Cc 11X0XPO! 2 8 (4,4) 3,2 [Cy| 7a— 01 
30 CB 32 SLH D 11X0XPO! 2 8 (4,4) 3,2 Ste 
81 CB 33 SLH E |1X0XPO! 2 8 (4,4) 3,2 y 
82 CB 34 SLH H 1)X0XPO! 2 8 (4,4) 3,2 
83 CB 35 SLH L 11X0XPO! 2 8 (4,4)* 3,2 
4 CB 36 SLH (HL) 11X0XPO! 4 15 (4,4,4,3) 6,0 
85 DD CB 05 36 SLH  (IX+IND) |!XO0XPO! 6 23 (4,4,3,5,4,3) 9,2 
86 FD CB 05 36 SLH  (IY+IND) |IX0XPO! 6 23 (4,4,3,5,4,3) 9,2 
87 DD 94 SUB XH VXIXVi! 2 8 (4,4) 3,2 
88 DD 95 SUB XL VIXIXVI! 2 8 (4,4) 3,2 
89 FD 94 SUB vYH VIXIXVi! 2 8 (4,4) 3,2 
90 FD 95 SUB YL VIXIXVi! 2 8 (4,4) 3,2 
91 DD AC XOR  XH !11X0XPO0 2 8 (4,4) 3,2 
92 DD AD XOR XL 11X0XPO0 2 8 (4,4) 3,2 
93 FD AC XOR YH 11X0XPO0 2 8 (4,4) 3,2 
94 FD AD XOR YL 11X0XPO0 2 8 (4,4) 3,2 
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MANUALUL DE UTILIZARE A CASETEI 
CU PRODUSUL —PROGRAM VISIBLE—Z80 ŞI CU 


PROGRAMUL PROIECTULUI CASEI DE MARCAT 


Atașarea unei casete program la o carte este o premieră în practica edito- 
rială din România. Scopul care se urmărește prin acest experiment este acela, 
de a pune la dispoziția cititorului un instrument care poate fi deosebit de util 
în asimilarea cunoștințelor despre microprocesorul Z80. Utilizînd un calculator 
personal, această casetă magnetică vă va permite să efectuaţi sesiuni de autoins- 
truire asistată de calculator, aprofundînd astfel materialul de studiu inclus în 
prezenta carte. 

Caseta conține programul VISZ8O (visible microprocessor Z80) elaborat 
de către autor, animat de dorința de a realiza un instrument care să permită 
concretizarea fenomenelor interne intime ale microprocesorului, dilatîndu-le în 
timp și spațiu astfel încît ele să poată fi percepute de sistemul senzorial al omu- 
lui. 

S-a realizat astfel un complex audio-vizual în care mișcarea și semnalele sonore 
converg spre un obiectiv comun : asistarea studiului. 

VISZ80 este un modul software de 24 kocteţi realizat în întregime în limbaj 
de asamblare. El se constituie din 6 blocuri funcționale majore : 

— monitorul propriu — oferă un set de comenzi care permit exploatarea re- 
surselor VISZ80. 

— asamblorul direct — permite elaborarea unor programe în limbaj de asam- 
blare, încărcînd codul translatat direct în memorie. 

— dezasamblorul — efectuează transpunerea inversă a programului din cod 
mașină în mnemonicele limbajului de asamblare ; programele aflate în memorie 
se traduc și se listează pe ecran. 

— procesorul grafic — este un pachet de programe care permit o tratare 
unitară a tuturor manevrelor ecran invocate de către simulatorul propriu-zis ; 

— simulatorul de instrucțiuni — simulează (pe cale software) execuția tutu- 
ror instrucțiunilor publicate ale microprocesorului Z80, păstrînd permanent, 
într-o zonă de memorie proprie, oglinda tuturor regiștrilor interni ai micropro- 
cesorului. | 

— supervizorul — dirijează execuția simulată a programelor cod-mașină, 
stabilind regimul de lucru și viteza de simulare a intrucţiunilnr:; el rezolvă și 
asortarea sonoră selectivă  oașilor de simulare. 
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În înregistrarea realizată pe caseta VISIBLE—Z80 au fost înglobate și cele 
67 rutine elaborate în studiul de caz din partea a treia a cărții (listing cap. 17), 
ele putînd fi oricînd străbătute cu ajutorul comenzilor oferite de către ambianța 
de lucru VISIBLE—Z80. 

Atașate, cele 2 module software formează o înregistrare de 28 kocteți. 

VISIBLE Z—80 a fost elaborat mai întîi pentru calculatorul PRAE—M 

Programele incluse se găsesc pe prima față a casetei. Pentru a veni în spriji- 
nul unui număr cît mai mare de utilizatori posibili, autorii au elaborat și o imple- 
mentare a acestui pachet de programe pentru calculatorul personal aMIC, înre- 
gistrare care se regăsește pe fața a doua a casetei. 


Procedeul de încărcare a celor două versiuni de implementare de pe cele 2 
fețe ale casetei diferă datorită diferențelor constructive și structurale ale celor 
2 calculatoare PRAE și aMIC. În ambele cazuri caseta se va poziționa în caseto- 
fon pe porțiunea de bandă ștearsă care precede înregistrarea de date. 


După instalarea BASIC-ului (V3.5) marcată prin afișarea mesajului READY 
se lansează comanda de încărcare. Dacă vă aflați la primul contact cu caseta 
VISIBLE—Z80 vă recomandăm să lansați o comandă de probă: 


ALOAD ”" 


Porniți casetofonul pe poziția REDARE (PLAY). După trecerea primului bloc 
de date, în colțul stîng jos al ecranului va trebui să apară titlul înregistrării: 
VISIBLE— Z80. Dacă evenimentul așteptat se produce, opriți derularea benzii, 
apăsați butonul RESET de pe panoul dorsal al calculatorului și tastaţi litera R 
pentru a reveni în BASIC PRAE. 

n acest caz există premisele pentru încărcarea fără eroare a înregistrării 
de pe casetă în memoria calculatorului. : 

Repoziționaţi caseta în amonte de înregistrarea de date și lansați apoi co- 
manda efectivă de încărcare : . 


LOAD ''VISIBLE—Z80” & 7000 


Porniți casetofonul pe poziția REDARE (PLAY). 


Va trebui să așteptați aproximativ 1 minut 55 secunde pînă cînd cei 28 
kbyte ai înregistrării vor defila în fața capului de citire a casetofonului. 


Odată cu terminarea blocurilor. de date, pe ecranul televizorului va trebui să 
apară mesajul de terminare a încărcării: 


— READY în cazul unei încărcări fără eroare 
— TAPE ERROR, urmat de READY în cazul unei încărcări cu eroare. 
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Dacă comanda de probă (ALOAD “ ') nu a avut efectul scontat, distingem 
două cazuri : 

— pe ecran nu se afișează nimic 

— pe ecran se afișează titlul incorect: caractere lipsă sau în plus, eventual 

se șterge întregul conținut al ecranului, 

În primul caz există probabilitatea racordului imperfect între casetofon și 
calculator. În acest caz va trebui să eliminaţi lipsa de contact făcînd încercări 
pe o casetă cuprinzînd înregistrările Dvs., pe care le-aţi citit deja. 

În cel de-al doilea caz racordul casetofon-calculator poate fi corect, dar 
semnalul citit de pe bandă nu este bun : el este fie afectat de zgomotul electric 
din mediu sau din rețea, fie capul de redare nu este reglat la nivelul etalon. 

Casetofoanele muzicale nefiind echipate pentru tehnica de calcul sînt puter- 
nic afectate de zgomotul electromagnetic. Astfel circuitele de baleiaj și cel de 
înaltă tensiune ale televizorului, precum și cele ale sursei în comutație a calcula- 
torului pot afecta, prin cîmpul lor electromagnetic calitatea transferului de date. 
De aceea vă rugam să dispuneți cît mai departe casetofonul de televizor și de 
sursă, amplasîndu-l cît mai la dreapta calculatorului și atelevizorului. Verificaţi 
traseul cablului de redare, ca acesta să nu formeze bucle, care pot acționa ca 
antene de recepție, și în nici un caz să nu încercuiască televizorul. 

Dacă nici aceste măsuri nu aduc rezultatul scontat, ștergeți capetele de înre- 
gistrare-redare a casetofonului cu o cîrpă moale îmbibată cu alcool tehnic. Veri- 
ficați ca banda să se deruleze ușor în casetă. Datorită unor imperfecțiuni ale 
rolei de antrenare, banda se poate depune neuniform pe rolă, ceea ce îngreunează 
antrenarea, provocînd variații de viteză la redare. În acest caz vă recomandăm 
să bateți caseta (pe ambele fețe) de palmă (în dreptul ambelor role) pînă cînd 
veţi constata că ea poate fi derulată ușor (folosind un obiect cu virf ex.: pix) 
în ambele sensuri. 

Dacă nici această manevră nu va îmbunătăți transferul de date, atunci pro- 
babil capul de redare este decalibrat. Înainte de a vă năpusti cu șurubelnița 
la șurubul de reglaj, trebuie să fiți conștienți de faptul că dislocînd capul riscați 
să nu puteți citi corect programele înregistrate în prealabil. 

Cunoscînd caracteristicile casetofonului care s-a livrat cu calculatoarele PRAE, 
am prevăzut în continuare o a doua înregistrare pe aceeași față a benzii. 

Cea de a doua înregistrare este efectuată cu viteză de transfer mai redusă 
(calculatorul PRAE permite acest lucru). Înainte de a încerca să efectuaţi citirea 
înregistrării făcută cu viteză de transfer redusă (1800 bit/sec. spre deosebire de 
2500 bit/sec. a înregistrărilor normale) va trebui să modificaţi parametrul de vi- 
teză (adresa &4018) al interfeței de casetă. Operația se poate efectua fie din 
BASIC PRAE folosind comanda : 


POKE &4018,&10 


fie din monitorul rezident al calculatorului, PRAE, folosind comanda de substituire 
în memorie : 


154018 OA 10 


După ce veţi fi modificat acest parametru, reluați încercările de încărcare 
descrise mai sus, știind că veți avea de așteptat mai mult, circa 2'42”, pentru 
derularea benzii. Dacă nici cu cea de a doua înregistrare nu veți putea scăpa de 
erori (TAPE ERROR) atunci va trebui să reglați capul de redare, sau să apelați 
la un alt casetofon. 
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Înţelegînd supărarea Dvs. (dacă veți fi ajuns în situația de sus) trebuie să 
vă precizăm faptul. că, caseta Dvs. a fost elaborată pe baza unei tehnologii meti- 
culos elaborate și verificate, de către specialişti ai Electrecord, și ea satisface 
într-adevăr condițiile calitative necesare pentru a putea fi citită fără erori pe un 
casetofon standard. 

Celor care vor fi avut dificultăți la încărcarea programului, ca și celorlalți 
de altfel, le recomandăm să-și creeze imediat, după o încărcare reuşită, o înregis- 
trare de rezervă (pe altă casetă) folosind comanda : 


SAVE “'VISIBLE—Z80'' &7000, &E000 


Dacă au existat probleme la citirea casetei originale, pe un casetofon cali- 
ficat de Dvs. drept bun, atunci ele vor fi probabil eliminate prin folosirea înre- 
gistrării create de acel casetofon. 

Vă mai amintim că la citirea oricărei înregistrări magnetice pot apare și erori 
aleatoare, care trebuiesc eliminate prin încercări succesive. (La dischetele magne- 
tice flexibile se efectuează pînă la 32 de iterații înainte de a se da mesajul de 
eroare. Din păcate, la casetofonul muzical această operație nu poate fi implemen- 
tată, datorită imposibilității de a da comanda sensului și vitezei de derulare a benzii 
precum. și timpului de redare mult superior). 

lată-ne ajunși în situația unei încărcări corecte. Programul VISZ80 se lansează 
în execuţie prin comanda : 


CALL & 7C11 


Pe ecran va apare Im. 218, imaginea de „trezire” a programului VISZ8O 
(vezi Im. 218) și se emite un semnal sonor. După aceea .se vor lista comenzile 
disponibile ale monitorului și programul trece în bucla de așteptare a unei comenzi. 
În acest moment VISZ8O se poate considera instalat. 
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Im. 218 


Recomandăm lansarea comenzii de încărcare din monitorul rezident al calcu- 
latorului. Caseta fiind poziționată în amonte: de înregistrarea de pe fața 2, tas- 
taţi comanda : 
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L (CR) 


şi apoi porniţi casetofonul pe poziția REDARE(PLAY). 

Dacă după încărcare, revenirea în programul monitor se face fără mesaje 
de eroare, VISZ8O se poate lansa în execuție cu comanda: G8017 (CR). 

Dacă apar erori la încărcare, vă recomandăm să efectuaţi verificările și încer- 
cările descrise mai sus la prezentarea comenzilor pentru calculatorul PRAE. 

Pe fața doi s-a generat o singură înregistrare, datorită faptului că aMIC nu 
permite înregistrarea și citirea programelor cu viteză programabilă. Crearea a 
două înregistrări de tip aMIC ar fi depășit spațiul util al casetei. 

Și în acest caz generarea unei înregistrări de rezervă este recomandabilă, 
imediat după prima citire reușită (salvînd pe o altă casetă conținutul spațiului 
de memorie cuprins între adresele 7000, și E000,), fiindcă orice casetofon poate 
înghiți accidental banda. Pentru acest din urmă caz comentariile sînt de prisos. 


Lista comenzilor oferite de monitorul încorporat-ordonate alfabetic- apare 
în imaginea de trezire a programului VISZ8O (vezi Im. 219). 


Fiecare comandă constă dintr-o literă urmată opțional de unui sau mai mulți 
parametri. Toate numerele care apar ca parametri ai unei comenzi sînt numere 
hexazecimale. Tastarea unor caractere ilegale va duce la abortarea comenzii (înainte 
de lansare), eveniment pe care monitorul îl va semnala afișind "x". , 


Comanda H (help) 

Tastînd litera H se afișează meniul de comenzi al monitorului încorporat. 

Comanda D (Dump memory) 

Comanda D permite vizualizarea (sub forma unor numere hexazecimale) 
a conținutului memoriei cuprinsă între două adrese limită. Se afișează pînă la 
opt octeți pe linie. La începutul liniei se afișează adresa de memorie a primei 
locații de pe rîndul respectiv. Formatul comenzii : Dadr1, adr2 (CR). 


— adr( este adresa de început, un număr hexazecimal cu 4 cifre semnificative 

— adr2 este adresa de sfîrșit, un număr hexazecimal cu 4 cifre semnificative 

— parametri pot fi separați prin virgulă sau spațiu 

— între D și adr1 nu se va pune spațiu 

— comanda se termină tastînd retur de car (CR) 

— dacă s-a comis o eroare la introducerea unuia din parametri, nu este necesară 
corectarea ei, căci se vor considera totdeauna ultimele 4 cifre hexazecimale. 
Un exemplu de utilizare al acestei comenzi se găsește în Im. 224. 
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Pentru urmărirea mai ușoară a listărilor lungi, după fiecare pagină de ecran 
afișată, pe rîndul de jos apare în invers video întrebarea: 


"TYPE (CR) FOR NEXT PAGE?” 


Dacă se tastează retur de car listarea continuă. Pentru orice altă tastă (ma; 
puţin SHIFT sau CTRL) listarea se abortează revenindu-se în secvența de aștep- 
tare a unei comenzi) („,>")). 


Comanda F (Fill memory) 


Cu această comandă se poate umple o zonă de memorie dată cu o valoare 
constantă. Formatul comenzii este : 


Fadri,adr2,nn (CR) 


— adrl este adresa de început a zonei tratate 

— adr2 este adresa de sfîrșit a zonei tratate 

— nn este un octet exprimat prin valoarea sa hexazecimală 

— ca separator de parametri se poate folosi caracterul spațiu sau virgulă 


Comanda | (Insert) 


Comanda permite înscrierea în memorie la adrese crescătoare a unui șir 
de valori, începînd cu o adresă dată. 
Formatul comenzii este : 


ladr,num 


— adr este adresa de început a zonei de memorie în care se face inserarea 

— num este valoarea care se dorește a fi înscrisă în memorie (1 octet) 

— pe un rînd se pot scrie mai multe date separate prin virgulă sau punct 

— dacă se tastează retur de car (CR) atunci se sare la rîndul următor la începu- 
tul căruia se afișează adresa de memorie la care se va face următoarea inserare 

— comanda se termină tastînd ESC (CTRL—U) 

— dacă după fiecare valoare numerică introdusă se tastează CR atunci utilizatorul 
va vedea fiecare număr în dreptul adresei de memorie, la care acesta se inse- 
rează. 


Comanda S (Substitute) 


Comanda S$ permite actualizarea unei zone de memorie, începînd cu o adresă 
specificată în lista comenzii. Ea va afișa conținutul curent al celulelor, fiecare valoa- 
re putînd fi substituită (opțional) cu alta. 

Formatul comenzii : 


Sadr, 


adr este adresa de început a zonei RAM care urmează să fie tratată. 

După adr se tastează „spațiu'”' sau „virgulă”!. În acest moment monitorul 
afișează valoarea curentă memorată în locația respectivă urmată de o liniuță. 
Dacă se dorește substituirea valorii respective se tastează noua valoare urmată 
de separator (',"' sau '' ''). După tastarea separatorului se afișează conținutul 
celulei următoare. Dacă nu se dorește modificarea unei celule, se tastează separa- 
torul. 

Comanda se termină cu tasta CR. 

Comanda X (eXamine or modify registers) 
Comanda X se poate lansa în două moduri: 
X(CR) şi 
Xreg,num 
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Prima formă se folosește pentru vizualizarea conținutului tuturor regiștrilor 
interni ai microprocesorului, sub formă hexazecimală, Se listează conținutul regiș- 
trilor :B, G, D, E, H, L, A, F, 8, CD 8, H* [i L A”, SĂ I, R, IX, dă SP, PC. 

A doua formă se folosește pentru vizualizarea și (opțional) modificarea con- 
ținutului unui registru selectat. 

— reg este numele registrului format obligatoriu din 2 caractere ; 2 litere, 
literă și apostrof, literă și spațiu (pentru cele cu nume format dintr-un singur 
caracter) ; După tastarea numelui, monitorul afișează valoarea curentă a regis- 
trului urmată de o liniuță '—", 

— num este valoarea (opțional) tastată pentru a modifica conținutul registru- 
lui selectat ; el are valoarea exprimată obligatoriu pe 2 sau 4 cifre hexazecimale 
(2 la regiștri simpli și 4 la regiștri dubli: PC, SP, IX şi 17); 

Tastările eronate nu pot fi corectate pe parcursul introducerii. În acest scop 
se va relansa comanda. (Această rigiditate derivă din formatul în care se memo- 
rează conţinutul regiștrilor interni ai microprocesorului, în VISZ80). 

Comanda se termină fie automat, după cele 2 (respectiv 4) cifre tastate, 
fie tastînd CR. (În cazul în care nu se dorește modificarea conținutului curent al 
registrului selectat). 


Comanda A  (Assemble) 


Comanda A invocă asamblorul încorporat în VISZ80, care permite introdu- 
cerea de la tastatură a unor programe scrise în limbajul de asamblare al micro- 
procesorului Z80 folosind argumente hexazecimale absolute. 

Asamblorul se lansează cu comanda: 


Aadr (CR) 


— adr este adresa de memorie începînd cu care se vor depune pe rînd codu- 
rile instrucțiunilor tastate, 

Asamblorul se anunţă prin afișarea adresei de început și preia apoi cîte o 
instrucțiune pe linie. După introducerea unei linii corecte (terminată prin CR) 
asamblorul depune codul obiect rezultat la adresa dată și revine în modul de edi- 
tare după afișarea adresei de asamblare a următoarei instrucțiuni. 

leșirea din asamblor se face prin introducerea unei linii goale (se tastează 
numai CR). 

—  Asamblorul din VISZ8O realizează doar traducerea mnemonicelor și nu- 
melor regiștrilor în cod binar executabil. Nu permite utilizarea etichetelor, a 
simbolurilor și cea a pseudoinstrucțiunilor. 

— La introducerea unei linii eronate VISZ8O afișează pe rîndul următor 
semnul ” ?”' şi cere repetarea liniei curente. 

— În cursul editării unei linii, se pot folosi următoarele caractere de con- 
trol : 

TAB(CTRL-—1) — introduce spaţii pînă la o poziție multiplu de 8. 

BS(CTRL—H) și DEL — șterg ultimul caracter introdus. Ștergerea se face 

atît în buffer cît și pe ecran. 

— Asamblarea instrucțiunilor de salt relativ JR, JR ce, DJNZ se face prin 

specificarea adresei absolute a instrucţiunii la care se va efectua saltul. 
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„Asamblorul va calcula deplasamentul și-l va depune în memorie în cîmpul 
instr ucțiunii respective. 
Considerînd forma liniei sursă 


(adr) (mnem) (adrsalt) (CR) 
se va respecta relația 
“(adr + 2) — 128 < adr.salt < (adr + 2) + 127 


unde adr4+2 este adresa instrucţiunii imediat următoare. 
n caz de neîncadrare, asamblorul va semnala eroarea, afișind "! ?" și invitînd 
astfel utilizatorul să introducă o linie corectă. 
Exemplu : 
A7000 (CR) 
7000 JR 7005 
7002 JR 7085 
, Ă 
7002 JR 7000 
7004 


— Semnalăm o mică anomalie a asamblorului încorporat în VISZ8O:: con- 
stantele care încep cu cifre hexazecimale literale (A—F) trebuie precedate de 0. 
În caz contrar asamblorul nu semnalează eroare, dar va genera cod eronat. 


Exemplu : 
corect incorect 
LD A,0F2 LD A,F2 


în memorie se va încărca 02 în loc de F2. 


Comanda L 


Comanda L invocă dezasamblorul, încorporat în VISZ8O care va dezasambla 
codul binar executabil, locat într-o zonă de memorie specificată și va lista mne- 
monicele rezultate pe ecran. 

Forma comenzii : 


Ladri,adr2 (CR) 


— adr. și adr2 sînt adresele de început respectiv sfîrșit zonă de dezasamblat. 
L va lista programul organizat pe linii (o instrucțiune/linie). Structura unei linii 
listate este : 


(adr) (cod obiect) (mnemonică) (argumente) 


— (adr) este adresa instrucţiunii curente, reprezentată prin 4 cifre hexazeci- 
male 


— (cod obiect) cuprinde de la 1—4 octeți, care reprezintă codul instrucţiunii 
listat în valori hexazecimale. 


— (mnemonica) — mnemonica instrucţiunii dezasamblate, în limbaj Z80 
— (argumente) — pot fi nume de regiștri sau valori hexazecimale. 


Pentru a putea întrerupe listările lungi, după afişarea unei pagini ecran, se 
va afișa în invers video mesajul : ; 


"TYPE (CR) FOR NEXT PAGE?” 
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Dacă se tastează retur de car (CR), listarea continuă. La apăsarea oricărei 
alte taste (mai puțin SHIFT şi CTRL) ea va fi abortată, revenindu-se în bucla 
principală a monitorului. 

Cunoaștem o anomalie (constructivă) a dezasamblorului. Instrucţiunile 
EX (SP)HL; EX (SP)IX; EX SP,(1Y); IN A, (n) şi OUT(n),A 
apar la-dezasamblare fără paranteze: EX SP,HL; EX SPIX:; EX SPIY; IN 
An şi OUT n,A. 


Secvențe de program cod mașină, depozitate în memorie pot fi 'ansate În 
execuție prin 3 comenzi: G, U și :C. 


Comanda G (Go to address) 


Este comanda majoră a pachetului VISIBLE—Z80. Comanda invocă simulato- 
rul propriu-zis (care este miezul lui VISZ80) și permite lansarea în execuția simu- 
iată (sub controlul lui VISZ80) a unui program, începînd de la o adresă (adr). 

Se pot stabili opțional pînă la 2 adrese de oprire breakp1 și breakp2. 

Formatul comenzii este 


Gadr,(breakp1),(breakp2) (CR) 


După lansarea comenzii, pe ecran se va desena structura internă a micro- 
procesorului Z80 și se va trece la execuția simulată a programului lansat într- 
unul din cele 7 moduri de simulare proprii simulatorului VISZ80. 

Definiţia modurilor de simulare și programarea lor va fi prezentată la descrierea 
comenzilor dedicate pentru supervizorul încorporat al VISZ80. 


Adresele de oprire (breakp) nu trebuie să fie neapărat adrese de început 
instrucțiune. Ele trebuiesc înțelese ca puncte de oprire pe adrese : dacă în orice 
moment al execuţiei simulate conținutul magistralei de adrese va deveni egal cu 
valoarea unui breakpoint, atunci execuția va fi abandonată : se actualizează con- 
ținutul regiştrilor şi se revine în monitor. Astfel execuția unui program poate fi 
stopată pe orice ciclu mașină extern procesorului. (Exemplu ciclul READ, WRITE, 
IN, OUT). 


Comanda U (Untraced go to address) 


Comanda U realizează transferul comenzii din VISZ80 la programul care 
începe la adresa specificată, îl execută în timp real și trece controlul din nou lui 
VISZ80, la întîlnirea unei adrese de breakpoint. 

Formatul comenzii : 


Uadr, (breakp1),(breakp2) (CR) 


În cazul utilizării acestor comenzi se recomandă ca programul să se termine 
cu instrucțiunea JP 8000. Astfel controlul va fi transferat înapoi la VISZ80 și 
fără a se folosi puncte de oprire. 

Restricţie : 

Revenirile din punctele de oprire s-au implementat prin salturi necondiţio- 


nate (pe 3 octeți). Din această cauză, în unele situații programul poate intra în 
„bălării” 
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Exemplu : 


7000 JP 7100 

7003 LD A.B 

7O0FF XOR A JP RESTART 
7100 LD B,40 

7102 LD 1X,4500 


Dacă punem un breakpoint la adresa 7OFF, acesta va ocupa 3 octeți (70FF— 
— 7101). Dacă în acest caz se execută ramura JP 7100, atunci codul instrucţiunii 
LD B,40 va fi alterat de către adresa de restart a punctului de oprire. 

Avantajul oferit de comanda U este acela de a permite utilizatorului rularea 
unor secvențe lungi și deja testate, în timp real. La returnarea comenzii în moni- 
tor, este posibilă execuția unei secvenţe interesante în regim simulat (comanda G). 


Comanda C (Call subroutine) 

Comanda C are același rol ca și comanda U. Ea transferă controlul la subru- 
tina aflată în memorie la adresa adr, 

Forma comenzii : 

Cadr (CR) 


La întîlnirea primei instrucțiuni RET sau RET cc cu condiția adevărată, 
controlul revine în monitorul propriu-zis VISZ80. 


Exemplu: 

A7000 (CR) 

7000 LD'50*B,3. 

7002 LD 0.41; ; codul lui „A"” 

7004 CALL 3154 ; console output Prae 
7007 DJ)NZ 7002 

7009 RET 

700A 

C7000 

AAA 


Prezența comenzii C ușurează apelul unor subrutine neinteresante, putîn- 
du-se continua apoi execuția simulată. 


Acest modul constituie esența pachetului de software VISIBLE—Z80. El 
desenează pe ecran structura internă a microprocesorului Z80 și derulează în 
timp toate activitățile care au loc în interiorul microprocesorului, atunci cînd el 
execută oricare din cele 696 instrucțiuni declarate. El se invocă prin comanda G 
a monitorului. 

Nivelul :de detailare a simulării poate varia în limite largi de la un regim mai 
detailat decît cel tact cu tact, la un regim instrucțiune cu instrucțiune. Gradul 
de detailare este programabil. Pentru același grad de detailare viteza de exe- 
cuţie este de asemeni programabilă. 
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Activităţile desfășurate pe ecran sînt subliniate prin secvențe sonore : în 
regimul cel mai detailat (îl numim impropriu tact cu tact — clock cycle — CC) 
fiecare mișcare ecran este urmată de emiterea unui sunet monoton (BEEP). Înce- 
putul ciclurilor mașină mai importante este marcat prin cîte o melodie care are 
menirea de a sublinia apariția unui eveniment interesant. 

Aceste efecte sonore sînt prezente la instalarea pachetului VISIBLE—Z80 
dar există comenzi care permit suspendarea și eventual revalidarea lor. Aceste 
elemente, care afectează regimul de lucru a simulatorului formează comenzile 
dedicate supervizorului. În funcție de situația în care se lansează le categorisim 
în două grupe :; comenzi statice și comenzi dinamice. 


Tastînd comanda M în monitor se afișează meniul de comandă al supervizo- 
rului (Mode menue). El se poate vedea în Im. 221. Odată intrați în acest meniu 
putem activa comenzile supervizorului de simulare (se afișează prompterul me- 
niului supervizor '"'—'"), 


Comanda E (Examine Simulation Switches) 


Tastarea acestei comenzi provoacă listarea sintetică a tuturor parametrilor 
de lucru importanți ai simulatorului. 


Modul de simulare (SIMULATION MODE): M 


poate avea șapte valori distincte. Ele determină regimul de lucru al simulatorului : 

M=0 — este cel mai detailat mod. Pe ecran se vizualizează toate activitățile 
interne ale microprocesorului. Rezoluția este mai mare decît cea tact cu 
tact (îl vom numi impropriu „tact cu tact” — CC) 

M=1 — blocurile funcționale reprezentate pe ecran se actualizează la sfîrșitul 
fiecărui ciclu mașină procesor. După fiecare activitate ecran execuția 
simulată este suspendată pînă la tastarea tastei (CR). De aceea acest 
regim se numește ciclu cu ciclu — manual (MC — manual). 

M=2 — se deosebește de M1 doar prin faptul că procesul de simulare decurge 
automat (fără tastări CR), lungimea pauzelor dintre pașii succesivi 
fiind programabilă (MC-—automat). 

M=—3 — este de asemenea regim manual. Execuția simulării va fi suspendată la 
sfîrşitul fiecărui ciclu instrucțiune și va fi reluată la apăsarea tastei 
(CR). (Regim Instruction Cycle — IC — Manual). 

M=4 — Impune un regim IC automat cu viteză programabilă. 

M=5 — Declanșează un regim de simulare numit trasor (TRACE). Pe ecran 
nu se vizualizează decît adresa, mnemonica și codul instrucţiunii care 
se execută. Viteza de execuţie este de asemenea programabilă. 

M=6 — Este modul de lucru rapid (FAST). Pe ecran nu se vizualizează nimic. 
Execuția vizibilă putînd fi reluată schimbînd modul de lucru după un 
breakpoint sau folosind una din comenzile dinamice ale supervizorului 
(o vom prezenta în continuare). 
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Temporizarea simulării (TIMING): T 


Este un număr exprimat pe un octet care determină lungimea unei pauze 
dintre 2 activități ecran în oricare din cele 5 regimuri automate (excepţii fac cele 
manuale M=1 și M=3) la care acest parametru este lipsit de sens). Se poate 
programa orice valoare cuprinsă între O — FF, dar supervizorul le va rotunji 
în jos la una din valorile: 30H, 70H, BOH, FOH pentru a le corela cu posibili- 
tățile oferite de cursorul de viteză SPEED (vezi comenzile dinamice). 


Deplasamentul locării programului (DISPLACEMENT): D 


A fost prevăzut cu o posibilitate de a relativiza adresele de memorie. Exemplu : 
dacă deplasamentului i se acordă valoarea 5000H atunci un program locat începînd 
cu această adresă va fi văzut de către simulator la adresa virtuală 0. 


Sunetul (BELL): B 


Este un comutator software care validează sau inhibă sunetul la fiecare activi- 
tate ecran (B=1 activează, B=0 inhibă). 


Cîntecele (SING): S$ 


Este comutatorul software care validează sau inhibă generarea melodiilor la 
începutul ciclurilor mașină semnificative ($=—1 validează, S=0 inhibă). 

Ciclurile subliniate cu melodii sînt: 

— începutul instrucţiunii (ciclul FETCH) 

— ciclul refresh (REFSH) 

— acceptarea unei întreruperi nemasabile (NMI) 

— acceptarea unei întreruperi mascabile (INT) 

— începutul unui ciclu (RESET) 

— stările suspendate (BUSAK) 

— încercarea de a scrie într-o zonă de memorie protejată 

— atingerea unei adrese de breakpoint. 

Frecvența sunetului și rapiditatea melodiilor sînt proporționale cu viteza de 
simulare (1). Un exemplu de folosire al acestei comenzi se poate vedea în 
im. 221. Revenirea din meniul supervizorului în bucla monitor se face tastînd 
(CR). 


Aceste comenzi se activează în timpul execuției simulate a unui program 
(lansat cu G). Ele se emit apăsînd mai scurt sau mai lung una din următoarele 
taste : 

M — provoacă abandonarea simulării și revenirea în monitor (">"). 

B  — simulează activarea semnalului BUSRQ. Dacă se apasă B.în modul de 
lucru M=0, BUSRQ se va afișa în invers video. Microprocesorul va intra 
în starea suspendată (HOLD) la încheierea ciclului mașină în curs desimu- 
lare. Starea HOLD este marcată de o melodioară specifică și afișarea în 
invers, video a semnalului BUSAK. Ieșirea din starea HOLD se face reapă- 
sînd tasta B. 

R  — simulează aplicarea semnalului RESET. Se va genera o melodie specifică. 
Se simulează activitățile intreprinse de microprocesor în cazul apariției 
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semnalului RESET, după care procesul de simulare va continua de la 
adresa 0000,.. 
| _— simulează un semnal de întrerupere "INT. VISZ80 comunică acceptarea 


comenzii prin trecerea în invers _ video a semnalului INT. Intreruperea 
mascabilă va fi acceptată la sfîrșitul instrucţiunii în curs de execuție, doar 
dacă IFF1 era setat IFF1=1). „+ 

N — simulează generarea unei întreruperi nemascabile. VISZ80 va trece în invers 
video semnalul NMI. La sfirșitul instrucţiunii curente întreruperea va fi 
acceptată. 

1,9 — sînt cele două taste de comandă, “barei de viteză SPEED. Cu ajuțorul 
lor se pot modifica concomitent parametrii M-—mod și T—temporizare. 

Bara notată cu SPEED asupra căreia se ște un cursor, indică viteza și 
modul de simulare ales pentru iii ea Pentru fiecare din ceJe 5 
regimuri de simulare principale (CC, MC, IC, TRACE, FAST) pe bara de viteză 
s-au rezervat segmente. Poziționarea cursorului (folosind tastele 1 și 9) va impune 
selectarea modului -de simulare adecvat. Segmentele sînt subdivizate. Aceste subdi- 
viziuni reprezintă o măsură a temporizărilor. 

Regimurile manuale (M=1 și M=—3) sînt marcate pe bara SPEED prin îngro- 
șarea subdiviziunilor aferente. Trecerea de la regim manual la automat și invers, 
se face implicit, odată cu mișcarea cursorului, eveniment semnalat de supervizor 
prin mesajele AUT sau MAN dispuse în dreapta barei SPEED. 


A.4. Exemple de lucru în ambianța VISIBLE—Z80. 


Vom prezenta în continuare cîteva secvențe de lucru cu ajutorul imaginilor 
generate prin însuși VISZ80. 

În Im. 219 se remarcă meniul monitor, urmat de prompterul '>>"' monitoru- 
lui. Urmează o secvenţă de utilizare a asamblorului, lansat cu comanda A7000(CR). 
În linia notată cu 700A s-a tastat CR revenindu-se în monitor. 

În Im. 220 se verifică codul asamblat, Polonă comanda L7000,700A (CR). 
Urmează exemplificarea comenzii H și a comenzii |. Cu ajutorul acesteia din 
urmă se fac două inserări (la adresele 7100 şi 7200). EA partea de jos a imaginii 
se exemplifică modul de utilizare a comenzii X. Im. 220 se termină cu utilizarea 
comenzii D pentru verificarea inserărilor făcute cu comanda |. 

În Im. 221 remarcăm lansarea comenzii M, urmată de afișarea meniului 
supervizor (MODE MENUE). Se ilustrează utilizarea comenzilor statice supervizor 
E şi S. În ultima linie se lansează în execuție cu breakpoint la 7009, (folosind 
comanda de acţionare a simulatorului, G), programul elaborat în Im. 219. 

În Im. 222 se imortalizează sfîrșitul primei instrucțiuni din program, iar în 
Im. 223 regăsim starea ecranului după atingerea adresei de oprire (7009). Regiștrii 
sînt actualizați, conform programului executat și oprirea este semnalată prin 
mesajul, „STOP AT BREAKPOINT”. 

Revenirea în: monitor se semnalează prin afişarea prompterului ”>”. 

În fine, ultima imagine, Im. 224, exemplifică o serie de comenzi monitor 
în care le remarcăm pe cele notate cu F,S și X. 
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Caseta de față poate fi utilizată de către oameni cu pregătire profesională 
foarte variată : începînd cu cei novici și terminînd cu utilizatorii profesioniști. 

Profesioniștii vor putea folosi VISIBLE—Z80 pentru a-și pune la punct progra- 
mele elaborate cu asambloare mai performante. Ei vor beneficia de comenzile 
propriu zise ale monitorului, și de cele de lansare U și C. 

Cei care cunosc deja cite ceva despre microprocesorul Z80 vor putea să-și 
asambleze instrucțiunile interesante folosind comanda A iar apoi să urmărească 
execuția lor simulată cu ajutorul comenzii G. 

Noncilor le recomandăm să lanseze, imediat după instalare, comanda G7000, 
simulatorul, iar după cîteva minute în care totul li se va părea de neconceput, 
îi invităm să parcurgă treptat, filă cu filă această carte și să recurgă la serviciile 
casetei ori de cîte ori vor simţi nevoia aprofundării celor citite. 

În fig. A.1. redăm harta memoriei celor două calculatoare personale PRAE 
și aMIC, avînd pachetul. VISIBLE— Z80 instalat. Din figură rezultă faptul că utiliza- 
torul își poate crea programe în următoarele zone RAM. 

PRAE : 4400, — 7F00,  ; aMIC: 61004 — 7FO0 și E0004 —FFFFU 

Protecţia memoriei. 

În timpul simulării unui program cu ajutorul comenzii G, zonele ZPU sînt 
singurele zone neprotejate la scriere. La întîlnirea unei operaţii de scriere la o 
locație de memorie protejată, simularea se întrerupe și se afişează mesajul : 

**R/O MEMORY AREA** 

Neprevederea acestei măsuri de protecție ar putea duce la autodistrugerea a în- 
suşi simulatorului. 

Protecţia memoriei nu este activă în cazul celorlalte comenzi monitor: 
rI,A,U și C. 

Instrucţiunile de |/O 

Pentru a preîntîmpina efecte nedorite (blocarea sistemului, pierderea ima- 
ginii, etc.) la simularea accidentală sau de test a instrucțiunilor de intrare/ieșire, 
acester instrucțiuni li s-a prevăzut: doar modul de execuţie pe ecran, fără ca ele 
să fie executate efectiv. Astfel la instrucțiunile de tip OUT data se transferă 
pînă la DB, iar instrucțiunile de tip IN de pe orice port vor forța valoarea 55. 
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S-a insistat mult asupra testării programului Visible—Z80, avind în vedere 
importanța punerii la dispoziţia utilizatorului a unui program cît mai corect posibil. 
Am fosț conștienți de faptul că testarea indică prezența erorilor — nu absența 
lor — și are dezavantajul că pentru un program complex este incomodă, necesi- 
tînd multe date și timp excesiv. Totuși, metoda folosită are avantajul că pro- 
gramul se execută în mediul său real, corespunzător utilizării lui finale. Pe aceas- 
tă cale este totodată posibilă evaluarea performanțelor programului tratat. 


S-a urmărit testarea tuturor componentelor software ale mediului Visible— 
Z80: monitorul încorporat, asamblorul, dezasamblorul, supervizorul, simulatorul 
de instrucțiuni și procesorul grafic. Ponderea cea mai ridicată și inclusiv volumul 
de muncă cel mai mare l-a constituit testarea ultimelor două componente. 

Testarea programului s-a făcut în cca 7 luni de zile de către un grup de spe- 
cialiști care n-au participat la elaborarea produsului. Prin aceasta s-a asigurat 
independența lui, astfel ca să nu fie influențat la testare de soluţiile adoptate 
şi aplicate la elaborarea programului. Se poate spune că s-a făcut o testare func- 
ţională (black-box), metodă care se aplică mai ales sistemelor finale, avînd avan- 
tajul de a detecta implementarea incorectă (neconformă cu specificațiile) a unor 
funcţii. 

S-a făcut atît testarea statică (analiza structurii programului, pentru selectarea 
setului de date de intrare), cît și cea dinamică (execuţia funcțiilor dedicate). 

Pentru testarea monitorului s-au executat comenzile acestuia, verificînd corec- 
titudinea execuţiei. 

Asamblorul s-a testat cu ocazia introducerii fiecărei instrucțiuni în vederea 
testării simulatorului. - 
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Dezasamblorul s-a verificat pe parcursul testării simulatorului, acesta afișînd 
în colțul din stînga sus a imaginii mnemonica instrucţiunii dezasamblate. 

Supervizorul s-a testat modificînd regimurile de lucru pentru una și aceeași 
instrucțiune executată și comparînd rezultatele între ele precum și cu cele teore- 
tice. În cadrul testării supervizorului s-a controlat și buna funcționare a procedu- 
rilor de simulare hardware implementate (BUSRQ, INT, NMI, etc.). 


Pentru verificarea simulatorului de instrucțiuni și a procesorului grafic s-a 
conceput un cadru unitar de testare. Astfel s-a elaborat o fișă de test tip. Fișa 
s-a completat la testarea fiecărei instrucțiuni a microprocesorului Z80. Instrucțiu- 
nile s-au testat în ordine alfabetică. 


lată conținutul fişei de test tip: 


1. Instrucţiunea MNEM COD MCy SCy SIMCy 

In această rubrică s-au trecut atît valorile teoretice preluate din documen- 
taţiile de referință (9) și (25) precum și cele determinate cu ocazia rulării instruc- 
țiunii cu ajutorul lui Visible—Z80. 

Semnificația simbolurilor folosite este : 

MNEM  — mnemonica instrucţiunii 


COD — codul instrucţiunii 

MCy — numărul de cicluri mașină (machine cycle) 

CCy — numărul de cicluri tact (clock cycle) 

SIMCy  — numărul de secvenţe grafice proprii lui Visible—Z80. 


2. Conţinutul iniţial al elementelor implicate 

Pentru a urmări buna funcționare a simulatorului de instrucțiuni, s-au ales 
valori numerice adecvate pentru regiștri implicați în instrucțiunea testată. 

3. Conţinutul final al elementelor implicate 

Asemănător punctului anterior, s-au completat valorile finale (datele de ieșir e, 
rezultatele) ale tuturor elementelor afectate de instrucțiunea testată ; 

4. Flaguri afectate: SZXHXPNC 

S-au consemnat atît valorile „teoretice”', conforme cu specificația micropro- 
cesorului, cît și cele consemnate cu ocazia rulării instrucțiunilor. 

În cazul instrucțiunilor care afectează indicatorii de condiţii (flaguri) s-au 
efectuat mai multe rulări, cu date de intrare diferite, în vederea verificării pozi- 
ționării corecte a fiecărui indicator în parte, 'completînd în acest scop rubrica 
„procedura de verificare utilizată”, 

Rezultatele s-au consemnat folosind următoarele simboluri : 

! — valoarea flag-ului este în funcție de rezultatul operaţiei 
— valoarea flag-ului nu este afectată 
— flag-ul P/V indică depășire 
— flag-ul P/V indică paritate 
— fără semnificație 
— valoarea flag-ului este zero 
— valoarea flag-ului este unu 

În cazul instrucțiunilor care nu afectează indicatorii de condiţie s-a trecut 
cuvîntul ,,Neafectate”. 

5. Anomalii constatate, descrierea clară a contextului. 

Au fost descrise anomaliile constatate, cu specificarea clară a contextului. 
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6. Data, semnătura 


S-a marcat data testării instrucţiunii şi a completării fișei de test, precum şi 
semnătura „controlorului de calitate". Rubrică pe cît de banală pe atît de im- 
portantă. 

Corespondenţa biunivocă între fișele de test și instrucțiunea testată, precum 
şi o referire simplă a instrucțiunilor verificate, au fost asigurate prin numerota- 
rea fișelor de test. 

Simularea uneia și aceleiași instrucțiuni s-a executat consecutiv, de mai multe 
ori, folosind diferite moduri de simulare, atît pentru verificarea acestora din 
urmă, cît și datorită faptului că a fost imposibil a se marca toate datele fișei de 
test, printr-o singură trecere. 

Prima trecere s-a făcut obligatoriu în modul de simulare cel mai detaliat 
(CC). Următoarele rulări s-au efectuat în regimul MC (ciclu mașină) și IC (ciclu 
instrucțiune). 

Dintre referințele bibliografice comparative, utilizate, amintim lucrările lui 
Rodnay Zacks (9) și dr. Makara Ern6ne (25). Prima referință bibliografică s-a 
dovedit a fi utilă datorită existenţei prezentărilor grafice sugestive a execuției 
instrucțiunilor și a poziționării indicatorilor de condiție. Din cea de a doua lu- 
crare s-a preluat numărul de tacți procesor repartizat pe cicluri mașină. Aceste 
elemente nu s-au regăsit în prima lucrare. 


Erorile detectate în timpul verificărilor pot fi grupate astfel : 
1, Erori generale, care afectează mai multe instrucțiuni : 


— poziționarea indicatorilor de condiții se face „,mut”, la fiecare instrucțiune, 
fără semnalul sonor specific fiecărei secvențe grafice ; 


2. Numărul de taci și numărul de cicluri mașină nu corespund cu cele indi- 
cate în referințele bibliografice utilizate ; 


Pe ecran apar concomitent mai mulți pași de simulare ; 
Poziționarea incorectă a indicatorilor de condiţie ; 
. Codul instrucţiunii nu se generează corect; 


Numerotarea greșită a unui ciclu de tact : de exemplu după tactul T=02, 
urmează imediat un tact cu numărul T=04. 


7. Greşeli ale asamblorului : 
8. Antetul imaginii vizualizate este eroriat. 


suay 


Cîteva erori semnalate la testare s-au dovedit a fi numai restricții de imple- 
mentare. Explicația acestor aparente anomalii se va da în paragraful următor. 

Din totalul de 728 (697+31) instrucțiuni testate, 243 au avut erori care au 
necesitat o depanare ulterioară. 

S-au urmărit aproximativ 19.000 de secvenţe grafice, testarea efectuîndu-se 
în aproximativ 230 de sesiuni de lucru a cîte șase ore. 
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Observațiile consemnate pe fişele de test au fost analizate de către elabora- 
torii programului. 

Erorile s-au eliminat consemnînd pe spatele fişei respective data și semnătura 
celui care a făcut corecţia. 

Unele anomalii semnalate le-am considerat a fi fenomene normale, caz în 
care am explicat cauza abaterii de la documentaţia de referință. lată pe scurt 
precizările făcute : 

a) Statutul de element afectat : 


Considerăm un element ca fiind afectat, în timpul unui ciclu sau al unei 
instrucțiuni, dacă în acest timp conținutul acestui element se schimbă, sau este 
testat de circuitul de comandă pentru luarea unei decizii. Astfel F este un regis- 
tru afectat de instrucțiunile de salt condiţionat. Astfel pe parcursul execuţiei 
unei instrucțiuni de tipul JP cc, nn conținutul registrului F este testat pentru 
a vedea dacă condiția cc este adevărată sau nu, chiar dacă conținutul lui F nu 
se schimbă. 

b) La unele cicluri mașină există cicluri de tact pentru care Visible—Z80 
nu arată nimic. Aceste cicluri „„vide'' apar în două cazuri: 

— tacți în care se execută operaţii interne (exemplu luarea unei decizii 
de către circuitul de comandă ; tacți de sincronizare). Acești tacți apar de obicei 
la sfîrșitul ciclurilor mașină. Credem că pe durata acestor tacți în Visible—Z80 
într-adevăr nu trebuie să se întîmple nimic; 

— la incrementarea/decrementarea regiștrilor dubli : 
regiștrii dubli precum și registrul R se incrementează/decrementează nu prin 
ALU ci prin intermediul unui registru de incrementare/decrementare care nu 
este reprezentat în modelul grafic al microprocesorului adoptat în Visible—Z80. 
În realitate o incrementare sau decrementare se realizează pe doi tacți : în pri- 
mul tact conţinutul registrului dublu este introdus în registrul de incrementare/ 
decrementare, iar pe al doilea tact conținutul incrementat sau decrementat este 
transferat înapoi în registrul dublu. Există o regulă : transferul Reg—» reg incr/ 
decr se realizează pe tacţii impari (T1, T3, T5) iar transferul înapoi pe tacţii 
pari T2, T4, T6. Nereprezentarea în registrul de incrementare/decrementare în 
modelul grafic adoptat în Visible—Z80 a dus la apariția unor inexactități în 
simularea activității de incrementare/decrementare a regiștrilor dubli. Astfel : 

— regiștrii dubli se incrementează pe un tact iar celălalt tact rămîne gol 

— nu s-a respectat o regulă clară privind momentul în care se simulează 

incrementarea sau decrementarea. Astfel în ciclul de REFRESH, schimbarea 
lui PC și R au loc în T2 respectiv T4, ce corespunde transferului conţi- 
nutului acestora din regiștrii de incrementare/decrementare înapoi ; dar 
la INC rr schimbarea lui rr se simulează pe T5 ceea ce corespunde mo- 
mentului de transfer în registrul de incrementare/decrementare. 

c) În cazul instrucțiunilor care se descriu pe 3 octeți de cod și un octet 
de deplasament, ciclul mașină intern — necesare — calculului adresei de indexare 
se suprapune peste ciclul de citire (fetch) al celui de-al treilea octet cod de in- 
strucțiume. Programarea concurentă a acestor două activități ar fi cauzat probabil 
ambiguități de interpretare. De aceea Visible—Z80 tratează cele două activități 
în cicluri mașină distincte, motiv pentru care numărul de cicluri mașină al aces- 
tor instrucțiuni diferă de cel real. 
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Exemplu : 


BIT 7, (IX+IND) 

M1 — 4 tacți procesor — fetch DD, 

M2 — 4 tacți procesor — fetch CB 

M3 — 3 tacți procesor — read IND 

M4 — 5 tacți procesor — efectuarea sumei IX-+-IND 

M5 — 4 tacți procesor — citirea octetului specificat, din memorie şi exe- 

cuția instrucţiunii. 

Comparînd această realitate cu fenomenologia din Visible—Z80 avem : 

Visible—Z80 — 4-+4+3+5+4-+4 tacţi procesor 

Real — 4+44+34+5 +4 tacți procesor 

d) Nu știm cum se realizează intern instrucțiunile RLD, RRD. De aceea un 
ciclu mașină, al acestor instrucțiuni este foarte sărac în Visible—Z80. 


În ciuda eforturilor depuse au rămas cîteva anomalii, care n-au putut fi 
eliminate din Visible— Z80, datorită în primul rînd lipsei de timp. În cazul unor 
erori am decis menținerea lor, datorită faptului că le-am considerat mai puţin 
semnificative, iar corectarea lor ar fi necesitat o restructurare prea amplă a pro- 
gramului. 

Anomaliile persistente le-am semnalat cu ocazia aventurilor din partea | 
a cărţii, dar le vom grupa şi în 'cele ce urmează : 

a) În cazul instrucțiunilor SBC HL, rr unde rr poate fi BC, DE, HL sau SP 
cel de-al treilea ciclu mașină durează patru tacți procesor. In Visible— Z80 durata 
lui este de 3 tacți procesor. 

b) În ciclurile mașină de tip OUT, comun tuturor instrucțiunilor de ieșire 
(OUT (n),A; OUT (C),r; OUTD, OTDR, OUTI, OTIR) semnalul WR se activează 
înainte ca datele de transferat să fie plasate pe magistrala de date. In realitate 
secvența este inversă (vezi capitolul D. „Datele de catalog ale microprocesorului 
Z80'', diagramele de timp a ciclului OUT). 

c) La acceptarea unei întreruperi mascabile salvarea valorii curente a conto- 
rului program PC se face la adresă eronată. În Visible Z80 s-a omis decremen- 
tarea prealabilă a lui SP (Stack Pointer) ; 

d) La intrarea în stare oprită (execuţia instrucţiunii HALT), Visible—Z80 
nu salvează valoarea curentă a contorului program PC în registrul WZ. Valoarea 
contorului program PC avansează la fiecare pseudo-fetch (NOP-uri), iar vechea 
valoare nefiind memorată nicăieri, execuția programului nu se va putea relua de 
la instrucțiunea următoare celei HALT (la acceptarea unei întreruperi). 


e) Dezasamblorul omite parantezele de adresare indirectă la șase instrucțiuni : 


EX  (SP)HL EX  SP,HL 
EX  (SP)IX EX  SP/IX 
corect EX  (SP),IY incorect EX" SPAIY! 
IN A,(n) IN An 
OUT (n),A OUT n,A 
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ADA D333 
BIM 280 


1„Iastzruoțiunea: 
MNEM COD NOy CO SIMOy 


2. Conținutul iniţial a] clenenetelox implicates 


3e Conţânutul final al clemenstelox implicate: 


be Flaguri afectate: 3 Z IX AL PF N 0 


. Procedura de verificaretutilizatăs 


5e Anomalii constatate, descrierea clară a contextuluit 


6, Data, sennătura: 


f) În fine amintim o eroare care s-a corectat în program dar ea persistă în 
imaginile unei aventuri din carte (lm.176—lm.184). Semnalul IORQ nu se acti- 
vează în ciclul de așteptare a unei întreruperi nemascabile. Rugăm cititorii să ne 
scuze pentru imposibilitatea de a mai corecta aceste imagini. 

Sîntem conștienți de faptul că testarea nu garantează corectitudinea absolută 
a programului, pentru că nu există încă nici o metodă de testare care să demon- 
streze că programul este fără erori. Testarea ne asigură că programul funcţio- 
nează corect pentru setul de date de intrare utilizat. Practica arată însă că tes- 
tarea statică asociată cu cea dinamică conduce la un program cu un grad ridicat 
de funcționalitate. 

Faptul, că s-a făcut testarea masivă a programului Visible—Z80 în sensul că 
simularea fiecărei instrucțiuni a microprocesorului Z80 a fost testată chiar de 
mai multe ori — bineînțeles nu şi toate combinaţiile de argumente posibile, — 
credem şi sperăm că îi conferă produsului un certificat de calitate și garanție. 
Totuşi în încheiere facem invitația către toți cititorii acestei cărți și către toți 
utilizatorii programului Visible— Z80 de a semnala pe o fișă de test eventualele 
erori descoperite. Vă recomandăm să vă ghidaţi după fișa model fotografiată în 
fig. B.1., care este o fişă reală, conținînd atît formularul tip, cît și completările 
făcute de cel care a testat instrucțiunea în cauză—fișa nr. 250, pentru instruc- 
ţiunea LD A,R. Editura și autorul dispun de toate cele 728 de fişe care au 
rezultat din testare). Mulţumim. 
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COMPARAŢIA SEMANTICĂ A LIMBAJELOR 
DE ASAMBLARE 18080 ŞI Z80 


Am amintit deja faptul că microprocesorul Z80 „este fratele mai mare” a 
microprocesorului 18080. El recunoaște și execută întocmai totalitatea instruc- 
țiunilor „fratelui mai mic'', posedînd totodată facilitatea de a executa suplimen- 
tar alte cîteva sute de instrucțiuni. 

La nivelul limbajului de asamblare ale celor două microprocesoare apar dife- 
rențe, chiar și în cazul instrucțiunilor comune, al căror cod binar executabil este 
identic. Din paragraful 3.3 știm deja că structura generală a unei instrucțiuni în 
limbaj de asamblare este identică pentru cele două procesoare în cauză. Dife- 
rențele totuși existente sînt de ordin sintactic și mai ales semantic. 

În prezentul capitol vom încerca să extragem și să explicăm aceste diferenţe. 

Începem cu lista explicitată a mnemonicelor celor două microprocesoare 
considerate. 


Tabela C.7. LISTA  .NEMONICELOR I 8080 


Nr Nr. de ins- 
*  Mnemonica Semnificaţia trucţiuni pe 
crt. 
care le descrie 
4, 2, 3. 4. 
1 ADC add with-carry — adună cu transport 8 
2 ADD add immediate — adună imediat 8 
3 ACI add with carry immediate — adună cu carry imediat 1 
4. ADI add immediate — adună imediat * 1 
Ş, ANA AND with accumulator — SI cu acumulatorul 8 
6. ANI AND immediate — SI imediat 1 
7 CMA complement accumulator — complementează acumulatorul 1 
8 CMC Complement carry — complementează transportul 1 
Ş, CMP compare — compară 8 
10. CPI compare immediate — compară imediat 1 
11. CALL call — apel 1 
12, CNZ call if non zero — apel dacă diferit de zero 1 
13, „4 call if zero — apel dacă zero :) 
14. CNC call if non carry — apel dacă nu e transport 1 
15, CC call if carry — apel dacă este carry pe 
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1 2 
16.  CPO 
17. CPE 
18. CP 
19. CM 
20.  DAA 
2.  DAD 
22. DCR 
23.  DCX 
24. Di 
25. EI 
26. HLT 
27. IN 
28.  INR 
29. INX 
30. MP 
3.  ÎNZ 
32. +.J2 
33. INC 
34. JC 
35.  JPO 
36. JPE 
37. JP 
38. JM 
39. LDA 
40.  LDAX 
41.  LHLD 
42. LXI 
43. MOV 
44. MVI 
45.  NOP 
46. ORA 
47. ORI 
48. OUT 
49.  PCHL 
50. PUSH 
51. POP 
52. RLC 
53. RRC 
54. RAL 
55. RAR 
56. RET 
57.  RNZ 
58. RZ 
59. RNC 
60. RC 
61.  RPO 
62. RPE 
63. RP 
64. RM 
65.  RST 
66. STA | 
67.  STAX 
68.  SHLD 
69. SUB 
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Tabela C7 (continuare) 


call if parity odd — apel dacă paritatea e impară 

call if parity even — apel dacă paritatea e pară 

call if plus — apel dacă pozitiv 

call.if minus — apel dacă negativ 

decimal adjust accumulator — ajustează BCD acumulatorul 


double add — adunare dublă 
decrement — decrementează 


decrement double register — decrementează registrul dublu 
disable interrupt — inhibă întreruperea 
enable interrupt — validează întreruperea 


halt — opreşte 


in — intră 

increment — incrementează 

increment double register — incrementează registrul dublu 
jump — salt 


jump if non zero — 
jump if zero — 
jump if non carry — 
jump if carry — 
jump if parity odd — 
jump if parity even — 
jump if plus 
jump if minus — 
load accumulator — 
load accumulator from dou- — 
ble register 

load HL direct — 
load double register imme- — 
diate 

move — 
move immediate — 
no operation — 
OR with accumulator — 


OR immediate — 
OUT — 
load PC with HL — 


PUSH on stack — 
POP from stack — 
rotate left with carry - 
rotate right with carry — 
rotate left arithmetic — 
rotate right arithmetic — 
return — 
return if non zero - 


“return if zero — 


return if non carry — 
return if carry — 
return if parity odd — 


return if parity even - 
return if plus — 
return if minus — 
restart — 
store accumulator — 
store accumulator from — 
double register 

store HL direct — 
subtract — 


salt dacă diferit de zero 
salt dacă zero 

salt dacă nu e transport 
salt dacă e carry 

salt dacă paritatea e impară 
salt dacă paritatea e pară 
salt dacă pozitiv 

salt dacă negativ 

încarcă acumulatorul 

încarcă acumulatorul „,după” 
registrul dublu 

încarcă HL direct 

încarcă registrul dublu imediat 


mută (transferă) 

mută (transferă) imediat 

nici o operaţie 

SAU cu acumulatorul 

SAU imediat 

ieși 

încarcă PC cu HL 

salvează pe stivă 

restaurează de pe stivă 
rotește la stînga cu transport 
rotește la dreapta cu transport 
rotește aritmetic la stînga 
rotește aritmetic la dreapta 
revenire 

revenire dacă diferit de zero 
revenire dacă zero 

revenire dacă nu e transport 
revenire dacă e transport 
revenire dacă paritatea e im- 
pară 

revenire dacă paritatea e pară 
revenire dacă pozitiv 
revenire dacă negativ 


relansare 
stochează acumulatorul 
stochează acumulatorul 


„după registrul dublu 
stochează HL direct 
scade 


DE e e e rs, e e e e n a e e e e es 
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Tabela C7 (continuare) 


BA 2, 3 4 
70. SUI subtract immediate — scade imediat 1 
71, SBB subtract with borrow — scade cu împrumut 8 
72. SBI subtract with borrow — scade cu împrumut imediat 1 

immediate 
73 STC set carry — înscrie transportul 1 
74. SPHL load SP with HL - încarcă SP cu HL 1 
75, XCHG exchange double register —  interschimbă registrul dublu 1 
76. XTHL exchange top of stack with - interschimbă virful stivei cu 
HL HL 1 
FE XRA EXCLUSIVE OR with accu- — SAU EXCLUSIV cu acumu- 
mulator latorul 8 
78. XRI EXCLUSIVE OR immediate — SAU EXCLUSIV imediat 1 
Total instrucţiuni : 244 
Tabela C.2. Lista mnemonicelor Z80 
Numărul 
iat Mnemonica Semnificația rege] 
le descrie 
a 2. 3. 4. 

1ă ADC add with carry — adună cu transport 15 

2. ADD add — adună 23 

3. AND AND — SI 11 

4. BIT test bit — testează bit 80 

5. CALL call - apel 9 

6. CCF complement carry flag —  complementează indicatorul 

de transport 1 

7, CP compare — compară 11 

8.  CPD compare & decrement — compară & decrementează 1 

9; CPDR compare, decrement, repeat — compară, decrementează, repetă 1 
10. CPI compare & increment — compară & incrementează 1 
11, CPIR compare, increment, repeat — compară, incrementează, repetă 1 
12. CPL complement (acumulator)  — complementează (acumulator) 1 
13.  DAA decimal adjust accumulator — ajustează BCD acumulatorul 1 
14, DEC decrement — decrementează 16 
15, DI disable interrupt — inhibă întreruperea 1 
16. DJNZ decrement, jump if non zero— decrementează, salt dacă dife- 

rit de zero 1 
+7) EI enable interrupt —  validează întreruperea 1 
18. EX exchange —  interschimbă 5 
TY. ae exchange X (all) — interschimbă X (toate) 1 
20. HALT  halt — oprește 1 
21. IM interrupt mode — modul de întrerupere 3 
220. IN in — intră 8 
23. INC increment — incrementează 16 
24. IND in & decrement — intră & decrementează 1 
vi INDR in, decrement, repeat — intră, decrementează, repetă 1 
26. INI In & increment — intră & incrementează 1 
DA INIR in, increment, repeat — intră, incrementează, repetă il | 
28. JP jump — salt 12 
29. JR jump relativ — salt relativ 5 
30. ma load — încarcă (transferă) 132 
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1 2 = 4 
31.  LDD load & decrement — transferă & decrementează 1 
32. LDDR load, decrement, repeat — transferă, decrementează, re- 

petă 1 
33. LDI load, & increment — transferă & incrementează 1 
34.  LDIR load, increment, repeat — transferă, incrementează, repetă 1 
35. NEG negative (A) - — negativ (A) 1 
36. NOP no operation — nici o operaţie Li 
37. OR OR — SAU 11 
38.  OTDR out, decrement, repeat — ieşi, decrementează, repetă 1 
39.  OTIR out, increment, repeat — ieși, incrementează, repetă 1 
40. OUT out — ieși 8 
41.  OUTD out & decrement — ieși & decrementează 1 
42.  OUTI out & increment — ieși & incrementează 1 
43. POP POP from stack — restaurează de pe stivă 6 
44. PUSH PUSH on stack — salvează pe stivă 6 
45. RES reset (bit) — resetează (șterge) bit 80 
46. RET return — revenire 9 
47.  RETI return from interrupt — revenire de la întrerupere 1 
48.  RETN return from non mascable — revenire de la întrerupere 
interrupt nemascabilă 1 
49. RL rotate left — rotește la stînga 10 
50.  RLA rotate left accumulator — roteşte la stînga acumula- 
torul 1 
51.  RLC rotate left with carry — rotește la stînga cu transport 10 
52.  RLCA  rotate left with carry A — rotește la stînga cu transport 
A 1 
53.  RLD rotate left digit — rotește la stînga cifră 1 
54. RR rotate right — rotește la dreapta 10 
55.  RRA rotate right accumulator — rotește la dreapta acumulator 1 
56. RRC rotate right with carry — rotește la dreapta cu transport 10 
57.  RRCA „rotate right with carry A  — rotește la dreapta cu transport 
A 1 
58. RRD rotate right digit — rotește la dreapta cifră 1 
59.  RST restart — relan$ge ia 9 
60. SBC subtract with carry — scădere cu transport 
(împrumut) 15 
61. SCF set carry flag — înscrie indicatorul de trans- 
i port 1 
62. ! SET set (bit) — înscrie (bit) 80 
63.  SLA shift left arithmetic — deplasează aritmetic la stînga 10 
64.  SRA shift right arithmetic — deplasează aritmetic la dreapta 10 
65. SRL shift right logic — deplasează logic la dreapta 10 
66. SUB subtract — scade 11 
67.  XOR EXCLUSIV OR — SAU EXCLUSIV 11 
Total instrucţiuni : 696 


Dacă comparăm cele două tabele putem face cîteva remarci. 


1. Limbajul de asamblare a microprocesorului Z80 exprimă 696 de instrucțiuni prin 
67 de mnemonici, pe cînd cel al microprocesorului 18080 folosește 78 de mnemonici pentru 
244 de instrucţiuni. Conţinutul semantic al mnemonicilor Z80 este mai mare (10,4 instruc- 
ţiuni/mnemonică) decît cel al mnemonicilor 18080 (3,1 instrucțiuni/mnemonică). 
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2. Densitatea de repartiție a instrucțiunilor pe mnemonici este neuniformă, ea variind 
între limite largi. 


18080 total Z80 total 

Instrucţiuni codificate mnemonici Instrucţiuni codificate mnemonici 
cîte :1 57 cîte :1 35 
cîte :2 2 cîte :3 1 
cîte :5 2 
cite :4 6 cîte :6 2 
cîte :8 12 cîte :8 3 
cîte :9 2 
cîte :63 1 cîte : 10 7 

78 

cîte : 11 5 
cîte : 12 1 
cîte :15 2 
cîte :16 2 
cîte : 23 1 
cîte : 80 3 
cîte : 132 1 
67 


Observăm că limbajul Intel folosește 57 de mnemonici distincte pentru simbolizarea 
a cîte unei singure instrucțiuni, pe cînd limbajul Zilog doar 35. Numărul maxim de instruc- 
țiuni simbolizate printr-o singură mnemonică este la Intel 63 (MOV) iar la Zilog 132 (LD). 

3. Mnemonicile-Intel sînt strîns corelate cu lumea hardware a microprocesorului. Distin- 
gem cîteva reguli: 

— Instrucţiunile ce folosesc adresarea imediată se disting de cele ce folosesc adresarea 
implicită, chiar dacă instrucțiunile aferente au aceeași funcție. Mnemonicile instrucțiunilor 
sii adresare imediată se termină cu litera | (immediate). Ex. ANA, ANI, ADD, ADI, CMP, 

PI, etc. 

— instrucțiunile care operează cu regiștri dubli conţin în mnemonică litera X, distin- 
gîndu-se de instrucțiunile ce operează pe regiștri simpli, chiar dacă funcţiile lor sînt similare. 
ex. INR, INX, MVI, LXI, DCR, DCX etc. 

— Instrucţiunile de salt condiționat (jump, call, ret) încorporează în mnemonică 
însăși condiția testată. Această discriminare forțată poate duce la dificultăți de identificare 
a mnemonicelor : cine își poate închipui că CC este de fapt tot o instrucțiune CALL?! 

4, Mnemonicele- Zilog sînt mai unitare,'ele urmărind o clasificare funcțională a instruc- 
ţiunilor. Detașindu-se prin generalitatea lor de detaliile de funcționare hardware a micro- 
procesorului, ele apropie mai mult limbajul de asamblare Z80 de limbajele de nivel înalt, 
invitîndu-l pe programator la gîndire mai abstractă. 


Apare o deosebire și în sintaxa de scriere a operanzilor. Limbajul de asam- 
blare Zilog prevede închiderea în paranteze a operanzilor care specifică adresarea 
indirectă. 

Exemple: a) JP (HL) — Zilog 

PCHL — Intel 

Cele două instrucțiuni sînt identice : se va efectua salt la adresa conținută 
în HL. Mnemonica Zilog exprimă logica fenomenului, iar cea Intel fenomenul 
fizic. 

b) LD B,.(HL) LD A,(BC) 
MOV B,M LDAX B 


Limbajul de asamblare Zilog este consecvent în marcarea transferului cu adre- 
sare indirectă, indiferent care registru dublu conține adresa de memorie. Lim- 
bajul Intel tolosește fie operandul M, cînd adresarea indirectă se face prin HL, 
fie marchează evenimentul în mnemonica instrucţiunii (LDAX). Această incon- 
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secvență îşi are și ea explicația : fizic microprocesorul identifică în mod diferit 
registrul dublu HL față de celelalte două (BC şi DE). 


c) LD A, (IX + IND) 


Această instrucțiune folosește adresarea indexată pentru a localiza celula de 
memorie al cărei conținut se va încărca în A. Adresarea indexată fiind în esență 
indirectă, regula privind folosirea parantezelor se aplică în acest caz. 18080 nu 
posedă instrucțiuni similare. 

Am prezentat comparativ limbajele de asamblare a două microprocesoare, 
pentru a fixa mai bine noțiunile și caracteristicile legate de aceste limbaje. Ele 
sînt menite să ușureze munca programatorilor, eliberîndu-i de povara memorării 
unor coduri. 


D 


DATELE DE CATALOG 
ALE MICROPROCESORULUI 780 
(Z80A, Z80B) 


În prezentul capitol redăm caracteristicile electrice și cele climatice ale 
microprocesorului prezentat. 


Datele de catalog se defalcă în două clase: 

— Valorile limită absolute 

— Valorile caracteristice 

În prima clasă se includ acei parametri care nu vor trebui depășiți în nici 
un caz, fabricantul declinîndu-și orice responsabilitate în acest caz. 

Între valorile caracteristice le distingem pe cele statice și pe cele dina- 
mice. 

Înșirăm prezentele date, publicate pentru produsul SGS—Z8400 (Z80), fiindcă 
ele sînt prezentate foarte metodic. 

Menţionăm că proiectanţii de hardware, vor trebui să confrunte aceste date cu 


cele concrete publicate de firma de la care provine procesorul pe care urmează să-l 
folosească. 


A. Valori limită absolute 


1. Temperatura ambiantă la funcţionare 0C— 70*C 
2. Temperatura ambiantă la stocare —65*C—150*C 
3. Tensiune pe oricare pin al capsulei faţă de GND —0,3V la +7V 
4. Putere disipată 1,5 W 


Depășirea oricărei valori de mai sus poate duce la defectarea iremediabilă 
a microprocesorului Z80. 


263 


B. Valori caracteristice 


Condiţii; TA = 0*C — 70*C; Vu =+5V4+5% 


Simbol  Parametru Min. Tip Max UM Condiţii de test 
Vuc Nivel O al tactului O —0,3 0,45 V 
Vie Nivel 1 al tactului & Vec —0,62 Vo V 
i Nivel 0 la oricare intrare  —0,3 0,8 v 
15 Nivel 1 la oricare intrare 2,0 Va V 
Vo. Nivel 0 la oricare ieşire 0,4 V lo, =1,8 mA 
Von Nivel 1 la oricare ieșire 2,4 V lou = —250 uA 
Ice Curent de alimentare 150, 200 mA 
200% mA  t, = 400 ns 
LI Curent absorbit la intrare 10 HA 0< Vu < Va 
Lon Curent de scurgere în „10 A Vour = 244+ Va 
tri-state 
lLo. Curent de scurgere în —10  uA  Vour =0,4V 
tri-state 
| urent de scurgere la 10 A 0<vV V 
LD Gsp g FU L. < Yn < ce 
Cg Capacitate de intrare 20 pF TA = 25*C 
pe O 8 =1 MHz 
CN Capacitate de intrare 5 pF 
Cour Capacitate de ieșire 10 pF 


* Z80, Z80A, Z80B 


Pinii nemăsuraţi sînt legați la masă 


Acești parametri se referă la timpii caracteristici ai diverselor semnale CPU, 
considerate în diversele cicluri mașină externe procesorului. 

Pe figurile D.1—D.8 redăm sub forma unor numere încercuite parametrii 
dinamici interesanţi ale căror valori se găsesc în tabela care completează prezenta 
anexă. 


E, e 


ră 


D.2. PARAMETRI DINAMICII 


Do-Dp 


Fig. D.2. Ciclul de citire/scriere memorie 


Fig. D.1. Ciclul mașină M1 (fetch) 
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PARAMETRI DINAMICI 


D.2. 


Fig. D.7. Acceptarea instrucţiunii HALT şi ieşirea din starea HALT (NMI) 


1—— 


CLOCK 


RESET 


Fig. D.8. Ciclul RESET 


Pentru a evita confuziile vom reda parametri dinamici păstrînd specificația 
lor originală. 


Z8400 234004 Z8400B 


Z80 Z80A Z80B 
Nr. Simbol Parametru ri 0 PRE CTP RE POETEI O PE 
- MIN MAX MIN MAX MIN MAX 
ns ns ns ns ns ns 
1. TeC Clock Cycle Time 400* 250* 165* 
2. TwCh Clock Pulse Width (High) 180* 110% 65* 
3. TwCl Clock Pulse Width (Low) 180 2000 110 2000 65 2000 
4. TIC Clock Fall Time 30 30 20 
5. TrC Clock Rise Time 30 30 20 
6. TdCr(A) Clockț to Address Valid Delay 145 110 90 
7. T4dA(MREQf) Address Valid MREQJDelay 125* 65* 35* 
8. TdCf(MREQf) Clockjto MREQ| Delay 100 85 70 
9. TdCr(MREQr) Clockțto MREQ ţ Delay 100 85 70 
10. TwMREQh MREQ Pulse Widht (High) 170* 110* 65* 
11. TwMREQI MREQ Pulse Width (low) 360* 220* 1358 
12. TdCf(MREQr) Clockjto MREQȚ delay 100 85 70 
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„ T4dCf(RDf) 

„ TdCr(RDr) 

„ TsD(Cr) 

. ThD(RDr) 

„ TsWAIT (Cf) 
. ThWAIT (Cf) 
. TdCr(M1f) 

. T4Cr(M1r) 

„ 7TdCr(RFSHf) 
. T4Cr(RFSHr) 
„ TdCf(RDr) 

. TdCr(RDf) 

. TsD(Cf) 


„ T4A(IORQ) 
„ T4Cr(IORQf) 
.. TACf(IORQr) 
. TAD(WRf) 

„ TdCI(WR1) 

. TwWR 

„ TACf(WRr) 

. TAD(WRf) 

. TACr(WRf) 

. TăWRr(D) 

. TACf(HALT) 
„ TwNMI 

„ TsBUSREQ(Cr) BUSREQ Setup Time to 


. ThBUSREQ 


(Cr) 


„ TACr(Az) 
. TACTr(A) 


. TsRESET(Cr) 
. ThRESET(Cr) 
. TsINT(Cr) 

. ThINT(Cr) 

. TAMI(IORQI) 
. TAC((IORQI) 


TACr(IORQr) 


. TdCf(D) 


Clockjto RD | Delay 
Clockţto RDȚDelay 

Data Setup Time to Clockţ 
Data Hold Time to RDȚ 
WAIT Setup Time to Clockj 
WAIT Hold Time after Clock] 
Clockţto M1|JDelay 

Clockţto M1ȚDelay 

Clockţto RFSH|Delay 
Clockţto RFSHȚDelay 
Clock|to RDȚDelay 

Clockţto RD|Delay 


Data Setup to Clockjduring 
M2, M3, M4, M5 Cycle 


Adress Stable prior to IORQJ 
Clockţto IORQJDelay 
Clockjto IORQȚDelay 
Data Stable prior to WR| 
Clock]to WR|Delay 

WR Pulse Width 
Clockjto WRŢDelay 

Data stable prior to WR| 
Clockţto WR|Delay 

Data Stable from WRŢ 
Clockjto HALTţor| 

NMI Pulse Width 


Clockţ 


BUSREQ Hold Time after 
Clockţ 


. T4dCr(BUSACKf) Clockţto BUSACK|Delay 
. TAdCf(BUSACKr) Clockjto BUSACKȚDelay 
. TdCr(Dz) 

. TdCr(CTz) 


Clockţto Data Float Delay 
Clockţto Control Output Float 
Delay (MREG, IORQ, RD, WR) 
Clockţto Address Float Delay 
Address Stable after MREQŢ, 
IORQŢ, RDŢ, WR 

RESET to ClockțSetup Time 
RESET to ClockțHold Time 
ÎNT to ClockțSetup Time 

ÎNT to ClockțHold Time 

MI |to IORQ|Delay 

Clockjto IORQJDelay 
Clockțto IORQȚDelay 
Clockjto Data Delay 


120* 


110 
100 
230 


95 
85 
35 
2.9 
PE - 
> 0 
— 400 
— 100 
în | 130 
= 120 
= 0 93 
e A 
Si i 
180*  — 
9 
a 45 
se  — 
— 80 
220  — 
ae 
48-— — 
a. * 68 
60e  — 
— 300 
8 0 
50 Anei 
[9] p-3 
— „150 
— 100 
— 90 
Po: 
a 0 
80*  — 
60 pi 
dom gtiă 
80 — 
= 6 
565 — 
5-93 
= LD 8 
— 1150 


80 
70 

30 
60 = 
Se 
Sa 
— 80 
— 410 
— 100 
221 9p 
ZA 
40 245) 
110 — 
LADT e 
ur XI 
25* i 
i eT 28) 
1359 — 
= 1) 
55 = 
a 
300  — 
SI, 
+ 033 
503, :.— 
[9] e 
SRR, 
e A 
— 80 
ea 
Adei 
ssei. — 
[XIRI 
mA 0 
201 
me ră 
7 II 
E: 
a 
= 13 


* Pentru valori mai mari ale perioadei de tact minime impuse, valorile normate se 
vor recalcula folosind expresiile din tabela următoare (În prezentele valori s-au considerat 
TrC=T(C=20 ns). 
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Condiţii de test folosite: 


VIH =20Y VOH = 2,0 V 
VIL =0,8vV VOL = 0,8 V 
VIHC = Va — 0,6 V 

VILC = 0,45 V 


Calculul parametrilor care depind de frecvenţa de tact 


, Z8400 Z8400A Z8400B 

Sp ai Z80 ZB0A Z808 

1. TeC TwCh + TwCl + TrC + TfC 

2. TwCh Deși regiștri microprocesorului sînt proiectaţi a fi statici nealterarea 
lor nu se garantează pentru TwCh mai mare decît 200 microsecunde. 

7. TdA(MREQ1) TwCh+TfC—75 TwCh+ TfC—65 TwCh+TfC—50 

10. TwMREQI TwCh+TfC—30 TwCh+ TfC —20 TwCh + TfC — 30 

11. TwMREQI TeC—40 TeC—30 TeC—30 

26. TdA(IORQf) TeC—80 TeC—70 TeC-—55 

29. T4D(WRf) TeC—210 TeC—170 TeC—140 

31. TwWR TeC—40 TeC—30 TeC—30 

33. T4dD(WRf) TwCl+ TrC—180 TwCl+ TrC —140 TwCl+ TrC—140 

35. T4WRr(D) TwC!+ TrC—80 TwCl+ TrC—70 TwCl+TrC-—55 

45. TdCTr(A) TwCl+ TrC—40 TwCl+ TrC—50 TwCl+ TrC— 50 

50. TdM1f(IORQf) 2TcC+ TwCh-+-TfC-— 2TcC+TwCh+TfC— 2TcC+TwCh+TfC-— 

—80 —65 — 50 


După cum rezultă din sintaxa simbolurilor, tipul parametrului este caracte- 
rizat de litere mici iar semnalele între care se măsoară se caracterizează cu 
majuscule. 


C — Cycle — ciclu (perioadă). 

d — delay — întîrziere 

h — high — nivel1 

| — low  — nivel0 

w — width — lățime 

f — fall — scăzător 

r — rise -— crescător 

s — setup — prestabilire (devansare) 
h — hold — menţinere 

z — float — stare flotantă (tristate) 


Proiectantul va asigura îndeplinirea următorilor parametri : 1,2,3,4,5,15,16, 
17,18,25,37,38,39,46,47,48,49. Dintre aceștia cei critici sînt : 1,2,3,4,5,15 17. 

Restul parametrilor, cei care nu s-au menționat în ultimele două secvenţe, 
vor fi asiguraţi de către microprocesor. 
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ANALIZA SETULUI DE INSTRUCȚIUNI 
ALE MICROPROCESORULUI Z 80 


În prezentul capitol redăm împărțirea detailată pe clase și pe grupe de instruc- 
țiuni. 

Împărțirea pe grupe de instrucțiuni am realizat-o după cum urmează : 

a) Am .definit un set de date (informaţii) semnificative, care sînt în măsură 
să caracterizeze oricare instrucțiune procesor. 

b) Am împărțit fiecare clasă în grupe de instrucțiuni, astfel încît membrii 
unei grupe să se asemene la majoritatea elementelor caracteristice definite. 


c) instrucțiunilor cuprinse în aceeași grupă le-am acordat mnemonici generice. 
Redăm în cele ce urmează clasificarea propusă. 


E.1. Clase și grupe de instrucţiuni, 
C|. 1. Instrucţiuni de transfer bit OA 
Mnemonici incluse : LD 
Totalul instrucțiunilor 
Număr -. 1 
Grupa 1: Instrucţiuni de transfer între regiştri: LD r1,r2 
Total instrucțiuni : 49 
Grupa 2: Instrucţiuni de încărcare regiştri din memorie: LD r,(mem) 
Total instrucţiuni : i 21 
Grupa 3: Instrucţiuni de transfer conţinut regiştri în memorie: LD (mem),r 
Total instrucțiuni : 21 
Grupa 4: Instrucţiuni de încărcare imediată a regiştrilor: LD r,n 
7 


Total instrucțiuni : 


Grupa 5: instrucţiuni de încărcare imediată a unor celule de memorie LD(mem),n 
Total instrucțiuni : 3 
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Grupa 6: Instrucţiuni de încărcare a acumulatorului din memorie: LD A,(rr) 
Total instrucțiuni : 2 


Grupa 7: Instrucţiuni de salvare a acumulatorului în memorie: LD (rr), A 
Total instrucțiuni : 2 

Grupa 8: Încărcarea acumulatorului din memorie prin adresare directă: LD A,(nn) 
Total instrucțiuni : 1 

Grupa 9: Salvarea acumulatorului în memorie prin adresare directă: LD (nn),A 
Total instrucțiuni: 

Grupa 10: Instrucţiuni de citire a regiştrilor hardware | şi R: LD A,rh 
Total instrucţiuni : 2 


Grupa 11: Instrucţiuni de programare a regiştrilor hardware | şi R:  LDrh,A 
Total instrucțiuni : 2 


CI. 2. instrucțiuni de transfer de 16 bit LOAD—16 
Mnemonici incluse : LD,EX,EXX,POP,PUSH 
Totalul instrucţiunilor din clasă : 39 
Numărul de grupe RL: 

Grupa 1: Instrucţiuni de încărcare imediată a regiştrilor dubli: LD rr,nn 


Total instrucțiuni : 6 
Grupa 2: Instrucţiuni de încărcare din memorie a regiştrilor dubli: LD rr,(nn) 
Total instrucțiuni : 6 
Grupa 3: Instrucţiuni de salvare în memorie a regiștrilor dubli: LD (nn),rr 
6 
4 


Total instrucțiuni : 


Grupa Instrucţiuni de încărcare a indicatorului de stivă SP din regi- 
ştri dubli: LD SP,rr 
Total instrucțiuni : 3 
Grupa 5: Instrucţiuni de salvare pe stivă a regiștrilor dubli: PUSH rr 
Total instrucțiuni *: 6 
Grupa 6: Instrucţiuni de restaurare a regiștrilor dubli din stivă: POP rr 
Total instrucțiuni : 6 
Grupa 7: Schimb de conţinut între regiştri dubli: EX DE,HL 
Total instrucțiuni ; Ă 
Grupa 8:  Interschimbarea regiştrilor primari cu cei secundari: EXX 
Total instrucțiuni : 1 
Grupa 9:  Interschimbarea regiştrilor de stare primari şi secundari: EX AF.AF' 
Total instrucțiuni : 1 
Grupa 10: Instrucţiuni de interschimbare a regiștrilor dubli cu vîrful 
stivei : EX (SP),rr 
Total instrucţiuni : 3 
CI. 3. Instrucţiuni de transfer de blocuri de date LOAD -—!DRA 
Mnemonici incluse : LDD, LDDR, LDI, LDIR 
Totalul instrucțiunilor din clasă : 4 
Numărul de prupe 7, 
Grupa 1: Transferuri simple: LDx 
Total instrucțiuni : 2 
Grupa 2: Transferuri multiple: LDxR 
Total instrucţiuni : 2 
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CI. 4. 


Mnemonici incluse : 


instrucțiuni aritmetice/logice pe 8 bit 
ADD,ADC,SUB,SBC,AND,XOR;OR, 


CP,INC,DEC,CPL,NEG,DAA,RLCA, 
RRCA, RLA,RRA 


Totalul instrucțiunilor din clasă : 115 
Numărul de grupe 5. 46 
Grupa 1:  Aritmetice— Adunarea simplă a regiştrilor: 


Grupa 2: 


Grupa 
Grupa 
Grupa 


Grupa 
Grupa 
Grupa 


Grupa 10: 


Grupa 11: 
Grupa 12: 
Grupa 13: 
Grupa 14: 
Grupa 15: 
Grupa 16: 


Grupa 17: 


Grupa 18: 
Grupa 19: 
Grupa 20: 
Grupa 21: 
Grupa 22 : 


Grupa 23: 


3 
4 
5 
Grupa 6: 
7 
8 
9 


Total instrucțiuni : 

Aritmetice— Adunarea regiştrilor cu adăugarea transportu- 
lui : 

Total instrucțiuni : 

Aritmetice— Scăderea simplă a regiștrilor : 

Total instrucțiuni : 

Aritmetice — Scăderea regiştrilor cu scăderea transportului : 
Total instrucțiuni : 

Logice — Operația ȘI cu regiştri : 

Total instrucțiuni : 

Logice — Operația SAU EXCLUSIV cu regiştri: 

Total instrucțiuni : 

Logice — Operația SAU cu regiştri : 

Total instrucțiuni : 

Logice — Comparaţia acumulatorului cu regiştri : 

Total instrucțiuni : 

Aritmetice — Adunarea simplă cu locații de memorie: 
Total instrucțiuni : 

Aritmetice — Adunarea cu adăugarea transportului (memo- 
rie) : 

Total instrucțiuni : 

Aritmetice — Scăderea simplă cu locaţii de memorie: 
Total instrucțiuni : 

Aritmetice — Scăderea cu scăderea transportului(memorie) : 
Total instrucțiuni : 

Logice — Operația SI cu locaţii de memorie: 

Total instrucţiuni : 

Logice — Operația SAU EXCLUSIV cu locaţii de memorie: 
Total instrucțiuni : 

Logice — Operația SAU cu locaţii de memorie: 

Total instrucțiuni : 

Logice — Comparaţia acumulatorului cu locaţii de memorie : 
Total instrucțiuni : 

Instrucţiuni aritmetice şi logice imediate 

ADD An; ADC An; SUB n; SBC An; 

AND n; XOR n; OR n; CPn; 

Total instrucțiuni 

Incrementarea regiştrilor simpli : 

Total instrucțiuni : 

Decrementarea regiştrilor simpli : 

Total instrucțiuni : 

Incrementarea locațiilor de memorie : 

Total instrucțiuni : 

Decrementarea locațiilor de memorie: 

Total instrucțiuni : 

Complementul față de 1: 

Total instrucţiuni 

Complementul față de 2: 

Total instrucţiuni : 


18 — Totul despre microprocesorul i 80 vol. 1 și 2 


AR/LOG=—38 


CP r 

7 Ă 

ADD A,(mem) 
3 


at A,(mem) 


SUB (mem) 
3 


SBC A,(mem) 
AND (mem) 
eta (mem) 
A (mem) 

3 


CP (mem) 
3 


8 


INC r 
7 


DEC r 
7 


INC (mem) 
3 

DEC (mem) 
3 

&PL. 


4 
NEG 
1 


273 


Grupa 24: 
Grupa 25: 
Grupa 26: 


Grupa 1: 
Grupa 2: 
Grupa 3: 
Grupa 4: 
Grupa $; 
Grupa 6: 


Grupa As 


Grupa 1: 


Grupa 2: 


dipue JE 
Grupa 2: 
Grupa 3: 
Grupa 4: 
Grupa 5: 
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Ajustarea BCD a acumulatorului : 
Total instrucțiuni : 

Rotirea acumulatorului „cu” carry : 
Total instrucţiuni : 

Rotirea acumulatorului „prin” carry : 
Total instrucţiuni : 


Adunarea simplă cu acumulatorul în HL: 
Total instrucţiuni : 

Adunarea simplă cu acumulatorul în IX: 
Total instrucțiuni : 

Adunarea simplă cu acumulatorul în |Y : 
Total instrucțiuni : 

Adunare cu adunarea transportului (carry) : 
Total instrucţiuni : 

Scădere cu scăderea transportului (carry): 
Total instrucțiuni : 

Incrementarea regiştrilor dubii : 

Total instrucțiuni : 

Decrementarea regiştrilor dubli : 

Total instrucțiuni : 


Comparări simple : 
Total instrucţiuni : 
Comparări multiple : 
Total instrucţiuni : 


Testarea biților din regiştri : 

Total instrucțiuni : 

Înscrierea (set)biților din regiştri : 

Total instrucțiuni : 

Ştergerea (reset) biţilor din regiştri : 
Total instrucțiuni : 

Testarea biților din locaţii de memorie: 
Total instrucţiuni : 


Înscrierea (set) biţilor din locații de memorie : 


Total instrucțiuni : 


ADD HL,rr 
i0D IX,rr 
Aoo WY,rr 
îpc HLrr 
tac HLrr 
ic rr 

€ 


DEC rr 
6 


BIT x,(mem) 
24 


SET x,(mem) 
24 


Ştergerea (reset) biților din locații de memorie: 
Total instrucţiuni : 

Manipularea bitului de transport (SCF,CCF): 
Total instrucțiuni : 


CI. 8. Instrucţiuni de salt 


Mnemon ic JP.JR.DJNZ 
Total tri r din clasă: 18 
Numărul 

Grupa 1 Salt necondiţionat absolut (direct): 


„Total instrucțiuni : 


Grupa 2 Salt necondiționat absolut (indirect): 
Total instrucţiuni : 
Grupa 3 Salt condiţionat absolut (direct) 
Total instrucţiuni : 
Grupa 4 Salt necondiţionat relativ : 
Total instrucțiuni : 
Grupa 5 Salt condiţionat relativ : 
Total instrucțiuni : 
Grupa 6 Salt condiţionat relativ, cu decrementare : 
Total instrucţiuni : 
CI. 9. Instrucţiuni de apel și revenire din subrutine 
Mnemoni ncluse : CALL, RET, RSŢ 
Total inilor d 
Naru : pe 
Grupa 1: Apel necondiţionat: 


Grupa 


2 
Grupa 3: 
Grupa 4 

5 


Grupa 


Total instrucţiuni : 
Revenire necondiționată : 
Total instrucțiuni : 
Apel condiționat : 


” Total instrucțiuni : 


Revenire condiționată : 

Total instrucţiuni : 

Apel scurt, necondiţionat, la adrese fixe: 
Total instrucțiuni : 


CI. 10. Instrucţiuni de rotire și deplasare 


MA 


Numărul de grupe 


Grupa 1: 
Grupa 2: 
Grupa 3: 


Grupa 4: 


ț 
| 


| instrucțiunilor din clas: 


Rotiri „cu” carry a regiştrilor (RLC,RRC): 
Total instrucţiuni : 

Rotiri „prin” carry a regiştrilor (RL,RR): 
Total instrucțiuni : 


Deplasări (shift) aritmetice a regiştrilor (SLA,SRA) : 


Total instrucțiuni : 


Deplasări (shift) logice a regiştrilor : 
Total instrucţiuni : 


ii]. CLASE ȘI GRUPE 


monici incluse ; RLC,RRC,RL,RR,SLA,SRA,SRL,RID, ! 


RES x, (mem) 
24 


xCF 
2 


JUMP 


JP nn 
1 

JP (rr) 
3 

JP c.nn 
8 

JR d 

E 

JR c,d 
4 
DJNZ d 
1 


CALL/RET 


CALL nn 

1 

RET 

1 

CALL c,nn 
8 


RET c 
8 


„RST n 


8 


ROT/SHIFT 


275 


Grupa 5: Rotiri „,cu” carry a locaţiilor de memorie (RLC,RRC): RxC (mem) 
Total instrucțiuni : 6 

Grupa 6:  Rotiri „prin” carry a locaţiilor de memorie (RL,RR): Rx (mem) 
Total instrucţiuni : 6 


Grupa 7: Deplasări (shift) aritmetice a locaţiilor de memorie (SLA, 
SRA) : i 


| SxA (mem) 
Total instrucțiuni : 6 
Grupa 8: Deplasări (shift) logice a locaţiilor de memorie: SRL (mem) 
Total instrucțiuni : 3 
Grupa 9:  Rotirea digiţilor de 4 biţi (RLD,RRD): RxD 
Total instrucţiuni : 2 
CI. 11 cțiu ntrare/ieşire N 
| D NDR,INIINIF DR.OŢIR 
Grupa 1: Input cu adresare directă : IN A,(n) 
Total instrucţiuni : e 1 
Grupa- 2: Input cu adresare indirectă: IN r,(C) . 
> Total instrucțiuni : | ? 
Grupa 3: Output cu adresare directă: OUT (n), A 
Total instrucțiuni : 1 
Grupa 4: Output cu adresare indirectă: OUT (C),r 
Total instrucțiuni : 7 
Grupa 5:  |/E blocuri de date — input simplu (IND,INI): INx 
Total instrucțiuni : 2 
Grupa 6:  I/E blocuri de date — input multiplu (INDR,INIR): INxR 
Ă Total instrucţiuni : 2 
Grupa 7:  I/E :blocuri de date — output simplu (OUTD,OUTI): OUTx 
i Total instrucțiuni : 2 
Grupa 8:  I/E blocuri de date — output multiplu (OTDR,OTIR): OTxR 
« Total instrucţiuni : 2 
CI. 12 Instrucţiuni de comandă SYs 
Mnemonici incluse DIE HALTȚ,IM,NOP,RETI.RETN 
Totalul instrucțiunilor din clasă: 9 
Numărul de grupe 5 
j Grupa 1: instrucțiunea HALT: HALT 
Total instrucţiuni : 1 
Grupa 2: Stabilirea modului de întrerupere: IM x 
Total instrucțiuni : ! 3 
Grupa 3: Validarea și inhibarea sistemului de întreruperi (EI,DI): xl 
Total instrucţiuni : 2 


Grupa 4:  Reveniredinrutinele de tratarea întreruperilor (RETI,RETN): RETx 
Total instrucţiuni-: 2 


Grupa 5: instrucţiunea NOP: NOP 
Total instrucţiuni : 1 
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E.2. File de instrucţiun: 


lată datele (informaţiile) caracteristice menite să definească complet oricare 
instrucţiune mașină a microprocesorului Z80 : 
„ Mnemonică 
„ Acţiunea 
„ Necesarul de memorie 
„ Necesarul de timp (timp de execuţie) 
„ Structura codului 
„ Tipuri de adresare folosite 
„ Flag-uri afectate. 


Pe paginile următoare găsiți cîte o filă (una sau două pagini) pentru fiecare 


NAmNAWN= 


din cele 98 de grupe de instrucțiuni enumerate la cap. E.1. 


LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 1 : Instrucţiuni de transfer între regiştri 


Mnemonica generică : LD rÎ,r2 


unde : ri și r2 potfi: A, B. C,D,E H sau L 
Total instrucţiuni ia ja 49 
Acţiunea sa pizzrie 


Conţinutul registrului r2 este transferat în registrul rî. Vechiul con- 
ţinut a lui ri se pierde. Conţinutul lui r2 rămîne neschimbat. 


Necesar de memorie : 1 byte 
Necesar de timp ; 4(4) tacți procesor 
Structura instrucţiunii CEI ARIEȘ 


byte 
unde : d2d1d0 reprezintă codul pe 3 bit al registrului destinație ri 
s2s1s0 reprezintă codul pe 3 bit al în bă sursă r2 
codurile posibile sînt : 000 — B 100 — 
001 — C 101 — L 
010 — D 110 
011 — E 111 — A 


Tipuri de adresare : destinaţie / sursă 
implicit  / implicit 


Memento de cod $ LD rl,r2 


D 
Lo 8740 pepe pp BT sf sf e Pa voMeLD Gr 


LD Dyr 50 He ps p.clp-ol el SOHeLD E,r 
LD Hp 60 FRERIn i popa if L,A|6oheLD Lr 


FT YyIVIIIVIIIVI 


4 
70% 70H+LD Ay 


cca ul se sea însumînd cele două numere arati rîndului 
și coloanei instrucţiunii căutate. 


Exemplu: LD DL 50H + 5 = 55H 
Flaguri afectate i nici unul 
Ale 
H PNG 
Exemple de utilizare : vol. Il p. 144 
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Clasa 1: Instrucţiuni de transfer de 8 bit 
Grupa 2 : Instrucţiuni de încărcare regiştri din memorie (read memory) 


Mnemonica generică _: r.14me! 1) 


unde : r poate fi A, B,C, D,E, HsauL 
mem poate fi HL, IX+IND sau IY+IND 
Total instrucțiuni 3* 7 =21] 


Acțiunea 


Conţinutul celulei de memorie avînd adresa specificată prin mem 
este transferat în registrul r. 


Vechiul conţinut al lui r se pierde. Conţinutul celulei de memorie 
folosite rămîne neschimbat. 
Necesar de memorie : 1 byte la LD r.(HL) 
3 byte la LD r,(IX+IND) sau 
LD r,(1Y+IND) 
Necesar de timp : 7 (4,3) tacți procesor la LD r, (HL) 
19 (4,4, 3, 5, 3) tacţi procesor la 
LD r,(IX+IND) sau 


LD r,(1Y+IND) 
"Structura instrucţiunii 
la LD r,(HL) 
cr la LD r,(IX + IND 
i 
byteo byte byte A ( sui ) 
CI | 
iz a ra a LD r,(1Y + IND) 
Tipuri de adresare : destinaţie / sursă 


implicit / indirect la LD r(HL) 
implicit / indexat la LD r,(IX+IND) 
sau LD r,(IY+IND) 


Memento de cod : E (mem) 
46 4Eu 56 5En 66n 6Eu76n 7En 


er Fopofreoeo 


Codul obținut este același pentru toate cele trei tipuri de instrucțiuni. 
La instrucțiunile indexate el apare în byte1. 


Flaguri afectate : nici unul 
e Ţ-[x[e xl: 


SZ +H sPNOy 
Exemple de utilizare : vol. Il p. 168 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 
Grupa 3: Instrucţiuni de transfer conținut regiștri în memorie (write memory) 


Mnemonica generică : LD (mem),r 


unde : mem poate fi HL, IX-+IND, sau IY+IND 
r poate fi A, B, C,D,E,HsauL 


Total instrucţiuni pp DA 
Acţiunea : (mem) e ommeil 


Conţinutul registrului r este transferat în memorie la adresa speci- 
ficată prin mem. Conţinutul lui r rămîne neafectat. Vechiul conţinut 
al celulei de memorie în care s-a făcut transferul se pierde. 


Necesar de memorie : 1 byte la LD (HL)r 
3 byte la LD (IX+IND), r sau 
LD (IY-+IND),r 
Necesar de timp ;.7(4,3) tacţi procesor la LD (HL), r 
19 (4,4, 3, 5, 3) tacţi procesor la 
LD (IX+IND), r sau 


LD (IY-+IND), r 
Structura instrucţiunii : 
poz la LD (HL), r 
Liri cocă 1 (NOI e] 
Bic EEE la LD (IX+IND),r 
Sea i] 
byteo byter sr 1 la LD (IY+IND)r 


Tipuri de adresare ; destinaţie / sursă 
indirect / implicit la LD (HL),r 
indexat / implicit la LD (IX+IND),r 
sau LD (IY+IND),r 


Memento de cod : LD (mem),r 


70H 71n 72H 73n 7&n 75u 76u 77H 


oefoefef atv a 
Codul obținut este același pentru toate cele trei tipuri de instrucțiuni. 


La instrucţiunile indexate el apare în byte1. 
Flaguri afectate : Sai Ru 


La PN Cy 


Exemple de utilizare : volll A 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 
Grupa 4: Instrucţiuni de încărcare imediată a regiştrilor 


Mnemonica generică LD r,n 


unde: r poate fi A, B, C, D,E,. HsauL 
n este un număr [0,255) 


Total instrucțiuni at d 
Acţiunea rr —— n 


Numărul n este înscris în registrul r. Vechea valoare cuprinsă în r 


se pierde. 
Necesar de memorie : 2 byte 
Necesar de timp ; 7 (4,3) tacţi procesor 


Structura instrucţiunii : A. 


byteo 


La adresa imediat următoare celei corespunzătoare codului, se află n 


Tipuri de adresare : destinaţie / sursă 
implicit / imediat 


Memento de cod : LD r,n 


064 OEu 164 1E 264 2Ew 36 3Eu 


Flaguri afectate , nici unul 


Sz H PNCy 


Exemple de utilizare : vol. Il 166 
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Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 5 : Instrucţiuni de încărcare imediată a unor celule de memorie (write 
memory) 


Mnemonica generică : EL NI eIT3). 


unde : mem poate fi HL, IX+IND sau IY+IND 
n este: un număr [0,255] 


Total instrucțiuni RI pede 
Acţiunea 


Numărul n este înscris în celula de memorie a cărei adresă este spe- 
cificată prin mem. Vechiul conținut al acelei celule de memorie se 


pierde. 
Necesar de memorie : 2 byte la LD (HL), n 
4 byte la LD (IX+IND),n sau 
la LD (1Y+IND),n 
Necesar de timp 3. 10(4,3,3) la LD (HL),n 
19 (4,4,3,5,3) la LD (IX+IND),n sau 


la LD (IY+IND),n 


Structura instrucţiunii 


PN RR la LD (HL),n 
Eee IEZI E la LD (IX+IND),n 
byteo byte byte2 te 
sira Da Me BAS: n la LD (IY+IND),n 
Tipuri de adresare : destinaţie / sursă 
indirect / imediat la LD (HL),n 
indexat / imediat la LD (IX+IND),n 
sau LD (IY+IND),n 
Memento de cod “LD (mem),n 
06H GEH16H 1En 26H 2Eu 36H 3EH 
Flaguri afectate i nici unul 


(= je je lă te» 2] 
Sz u PN Ey 
Exemple de utilizare : vol. Il, p. 162 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 6: Instrucţiuni de încărcare a acumulatorului din memorie (read memory) 


Mnemonica generică  : LD A,(rr) 


unde : rr poate fi BC sau DE 


* Total instrucţiuni al i 
Acţiunea : e (rr) 


Conţinutul locației de memorie adresată prin registrul dublu rr, este 
transferat în acumulator. Conţinutul vechi al acumulatorului se pierde 
Conţinutul celulei de memorie implicate rămîne neschimbat. 


Necesar de memorie : 1 byte 


Necesar de timp ; 7 (4,3) tacți procesor 


Structura instrucţiunii : 


byte 


Tipuri de adresare : destinaţie / sursă 
implicit  / indirect 


Memento de c; i LD A,rr) 
OAH ——-— LD A,(BC) 
1AH ——— LD A,(DE) 
Flaguri afectate : nici unul 


SI N PNO 
Exemple de utilizare _: vol. Il, p. 146 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 7 : Instrucţiuni de salvare a acumulatorului în memorie (write memory) 


Mnemonica generică : LD (rr), A 


unde : rr poate fi BC sau DE 


Total instrucțiuni | e Ai 


Acţiunea : (rr) — A 


Conţinutul acumulatorului este înscris în celula de memorie avînd 
adresa specificată în registrul dublu rr. Vechiul conţinut al celulei de 
memorie se pierde. Conţinutul acumulatorului rămîne neschimbat. 


Necesar de memorie : 1 byte 

Necesar de timp ; 7 (4,3) tacți procesor 
Structura instrucţiunii Die 

Tipuri de adresare ; destinaţie / sursă 


indirect  / implicit 


Memento de cod : LD (rr), A 

i 02H ——-— LD (BC),A 
12H ——— LD (DEJA 

Flaguri afectate i nici unul 


Se H PNG 
Exemple de utilizare : vol. Il, p. 146 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit. 


Grupa 8 : Încărcarea acumulatorului din memorie, prin adresare directă. 


Mnemonica generică _: LD A,(nn) 


unde : nn este o adresă [0,65535] 


Total instrucțiuni EN Ai, 


Acţiunea A fr (nn) 


Conţinutul celulei de memorie avind adresa nn este transferat în 
acumulator, Vechiul conținut al acumulatorului se pierde. Conţinutul 
celulei de memorie folosite nu se schimbă. 


Necesar de memorie : 3 byte 


Necesar de timp ; 13 (4,3,3,3) tacți procesor 


Structura instrucţiunii : Cha j 
byteo byte: ez 


byte 1 conține octetul inferior al adresei nn 
byte 2 conţine octetul superior al adresei nn 


Tipuri de adresare : destinaţie / sursă 
implicit / direct 


Memento de cod :LD A,(nn) 
cod : 3AH 
Flaguri afectate : nici unul 


| E EI EICI PA EI EI EI 


$.2- -H 1PN.Cy 
Exemple de utilizare _: vol. II, p. 210 
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LOAD — 8 


Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 9 :. Salvarea acumulatorului în memorie prin adresare directă 


i Ampeei generică _: LD (nn), A 


“unde : nn este o adresă [0,65535) 
Total instrucţiuni A, 
Acţiunea : (nn) — A 
Conţinutul acumulatorului este depus în celula de memorie care are 


adresa nn. Vechiul conţinut al celulei respective se pierde. Conţinu- 
tul acumulatorului rămîne neschimbat. 


Necesar de memorie : 3 byte 

Necesar de timp ; 13 (4,3,3,3) tacţi procesor 

sar ge da 
byteo byte: byte2 


byte 1 conţine octetul inferior al adresei nn 
byte 2 conține octetul superior al adresei nn 


Tipuri de adresare : destinaţie / sursă 
„direct / implicit 


Memento de cod : LD (nn), A 
cod ; 32H 
Flaguri afectate : nici unul 


Le Lele [Xe] 
S2. Ha Ni 
Exemple de utilizare : vol. II, p. 210 
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Clasa 1: Instrucţiuni de transfer de 8 bit 


Grupa 10: Instrucţiuni de citire a regiștrilor hardware | și R 


Mnemonica generică : -.- Ar n 

unde : rh poate fi | sau R 
Total instrucțiuni d 1=2 
Acţiunea 


Conţinutul registrului special | sau R este transferat în A. Vechiul 
conținut al registrului A se pierde. Conţinutul registrului hard nu 


se schimbă. 
Necesar de memorie : 2 byte 
Necesar de timp ; 9 (4,5) tacţi procesor 


Structura Instrucțiunii : 
byteo byte: 


Se execută două cicluri fetch (M1) consecutive, 


Tipuri de adresare ; destinaţie / sursă 
implicit / implicit 


Memento de cod : a | 


EDH 57H ——-— LDA, 
EDH 5FH ——— LD A;R 
Flaguri afectate : unica grupă de transfer de 8 bit, care afectează indi- 


catorii de condiţie : sînt afectați toți indicatorii cu 
excepția lui carry. 


S-z- H-P-N-Cy 
TE coninutul lui IFF2 


Această instrucțiune permite (este de altfel unica soluție) identificarea 
stării sistemului de întreruperi pe cale software. 
Aspectul este interesant în sisteme cu întreruperi multiple. 


Exemple de utilizare : vol. II, p. 197 
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LOAD — 8 


Clasa 1 : Instrucţiuni de transfer de 8 bit 


Grupa 11 : Instrucţiuni de programare a regiștrilor hardware | și R 


Mnemonica generică : LD rh, A 


unde : rh poate fi | sau R 


Total instrucțiuni a ti 


Acțiunea rh — A 


Conţinutul acumulatorului este transferat în registrul special selectat. 
Vechiul conținut al acestui registru se pierde. Conţinutul. acumulato- 
rului nu se schimbă. 

Necesar de memorie : 2 byte 


Necesar de timp ; 9 (4,5) tacți procesor 


Structura instrucţiunii : 
byteo byte; 


Se execută două cicluri fetch (M1) consecutive. 


Tipuri de adresare ; destinație / sursă 
implicit / implicit 


Memento de cod ; LD rh,A 
EDH 47H ——— LDI,A 
EDH 4FH ——— LDR,A 
Flaguri afectate ; nici unul 
a 
Hi PNG 
Exemple de utilizare : vol. A: p. 23 
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LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit % 
Grupa 1 : Instrucţiuni de încărcare imediată a registrilor dubii 


Mnemonica generică : LD rr,nn 


unde : rr poate fi BC, DE, HL, SP, IX sau IY 
nn este un număr [0,65535] 


Total instrucțiuni î 1 ==0 


Acţiunea : TFlow — nnlow 
rrhigh — nnhigh 


Registrul dublu rr este încărcat cu valoarea nn. Vechiul conţinut al 
registrului dublu se pierde. 


Necesar de memorie  ; 3 byte pentru BC, DE, HL sau SP 
4 byte pentru IX sau IY 


Necesar de timp ; 10 (4,3,3) tacţi procesor pentru BC, DE, HL sau SP 
: 14 (4,4,3,3) tacți procesor pentru IX sau IY 


Structura instrucţiunii : 


Cana pentru BC, DE, HL sau SP 
by teo II te 2 
pentru IX 
byt byte byte: byte3 
a mt pentru IY 
yteo b 


Tipuri de adresare : destinaţie / sursă 
implicit / imediat 
Memento de cod : LD rrnn 


01 H 11_H___21H 31H 


Cc oc Fo se ] 


Pentru regiștri IX și IY codul 21H este precedat de DDH respectiv 


FDH 
Flaguri afectate i nici unul 
e Le jX.je |X [e de lei 
ȘIZIHI PNG 
Exemple de utilizare : vol. Il, p. 144 
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Clasa 2: Instrucţiuni de transfer de 16 bit 
Grupa 2 : Instrucţiuni de încărcare din memorie a regiştrilor dubli (read memory) 


Mnemonica generică : LD rr,(nn) 


unde : rr poate fi BC, DE, HL, SP, IX sau IY 
nn este o adresă [0,65535] 


Total instrucțiuni 


Acţiunea 


E e DY 
rrlow “— (nn) 
rrhigh —— (nn + 1) 


Registrul dublu rr este încărcat din memorie, cu 2 octeți, începînd 
de la adresa nn. Conţinutul vechi al registrului dublu se pierde. Con- 
ținutul celulei de memorie implicate rămîne neschimbat. 


Necesar de memorie 


Necesar de timp 


Structura instrucţiunii 


Tipuri de adresare 


Memento de cod 


codi 


cod2 


3 byte pentru HL 
4 byte pentru BC, DE, SP, IX sau IY 


16 (4,3,3,3,3) tacți procesor pentru HL 
20 (4,4,3,3,3,3) tacți procesor pentru BC, DE, SP, IX 
sau |IY 


E ati) bohtru eti 


byt 


byteo byte byte 2 

sii Ea ŢI pentru IX 
byte, e te: 

2 codi 
byte 


destinație / sursă 
implicit / direct 


LD rr,(nn) 
2AH pentru HL, IX, IY 


4B_H_ _SBH 68 H _7BH 


ee: 
+ 
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Observaţie ; cod2 = 6BH definește aceeași instrucțiune ca și cod1=— 
2AH ; astfel instrucțiunea LD HL,(nn) este definită 
pentru două secvențe de cod: 
2A nn low nnhigh și ED 6B nnlow nnhigh 


Flaguri afectate ; nici unul 


e elle xLe[e [e] 
Z 


S H PN Cy 


Exemple de utilizare : vol. ||, p. 149 


LOAD. — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 3 : Instrucţiuni de salvare în memorie a regiștrilor dubli (write memory) 
prin adresare directă 


Mnemonica generică : LD (nn), rr 


unde : nn este o adresă [0,65535) 
rr poate fi BC, DE, HL, SP, IX sau IY 


Total instrucțiuni ; tr Zir3=6 


Acțiunea : (nn) — TTrlow 
(nn + 1) — rrhigh 


Registrul dublu rr este transferat în memorie în două locaţii succesive, 
începînd cu adresa nn. Vechiul conţinut al celulelor specificate se piet- 
de. Conţinutal registrului dublu rămîne neafectat. 


Necesar de memorie : 3 byte pentru HL 
4 byte pentru BC, DE, SP, IX sau IY 


Necesar de timp 16 (4,3,3,3,3) tacți procesor pentru HL 


20 (4,4,3,3,3,3) tacţi procesor pentru BC; DE, SP, 1x 
sau |Y 


Structura instrucţiunii 


pentru HL 


STA b 1e 
Ey paz E —, Casa) pentru IX 
ie ma aaa 


Ei [aha __] pentru |Y 

Ep Cei ED) (ET) [ii] pentru BC, DE sau SP 
byteo byte: byte2 bytez ș 

Tipuri de adresare ; destinaţie / sursă 


direct / implicit 
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Memento de cod 


cod1 


cod2 


Observaţie 


Flaguri afectate 


Exemple de utilizare 


si 
0004 004% 
Date 


cod2=63H definește aceeași instrucțiune ca și 22H. 
Astfel, instrucțiunea LD (nn),HL este definită pentru 


două, secvențe de cod: 22 nnlow nnhigh și ED 63 
- nnlow nnhigh. | 


: LD (nn)rr 


22H pentru HL,IX,IY 


835 Sa S3.H. 73 


nici unul 


(*jelXLejăLe lee) 


e apelul e aug 21 me E a 


: vol. ||, p. 148 


LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 4: Instrucţiuni de încărcare a indicatorului de stivă SP din regiştri dubli 


Mnemonica generică LD SP,rr 


unde rr poate fi HL, IX sau IY 


Total instrucțiuni RIC E e) 
Acţiunea : SP —— rr 


Indicatorul de stivă SP este încărcat din. registrul dublu rr. Vechiul 
conținut al lui SP se pierde. Conţinutul registrului sursă rr rămîne 
nealterat. 


Necesar de memorie : 1 byte pentru HL 
2 byte pentru IX sau IY 


6 (6) pentru HL 


Necesar de tim i 
x 10(4,6) pentru IX sau IY 


Structura instrucţiunii 


pentru HL 


ju 


pentru IX 


ja co) 
CO centru iv 


(i 


Tipuri de adresare ; destinaţie / sursă 
implicit / implicit 


Memento de cod : LD SPrr 
cod E riul 
Flaguri afectate ; nici unul 


e e Xe lxLe [ele] 


Sz H PNG 


Exemple de utilizare 


294 780 — ANALIZA INSTRUCȚIUNILOR 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 5 : Instrucţiuni de salvare pe stivă a regiştrilor. dubli (write memory) 


Mnemonica generică : P U $ ia rr 
unde : rr poate fi BC, DE, HL, AF, IX sau IY 
Total instrucțiuni i: 6x11 =4 
Acţiunea : SP SP 7 
(SP) —— rfhigh 
SP = SP 1 
(SP) — rrlow 


Conţinutul registrului dublu rr este salvat în memorie la adresa speci- 
ficată de indicatorul de stivă SP. Salvarea se face la adrese descrescă- 
toare, prima salvare implicînd octetul superior al registrului rr. 
Conţinutul registrului dublu rr rămîne nemodificat. 

Conţinutul indicatorului de stivă se decrementează cu 2. 


Necesar de memorie ': 1 byte pentru BC,.DE, HL sau AF 
2 byte pentru IX sau IY 
Necesar de timp ; 11 (5,3,3) tacți procesor pentru BC, DE, HL sau AF 


15 (4,5,3,3) tacți procesor pentru IX sau IY. 


Structura instrucţiunii 


pentru BC, DE, HL sau AF 
byte 
pentru IX 
pentru IY 


byteo byte 
Tipuri de adresare ; destinaţie / sursă 
indirect / implicit 
Memento de cod : PUSH rr 


C5H D5SH ESH F5H 
Doc [oc ea] ae ] 


Flaguri afectate nici unul 


Le je lxlelxle le Le) 
SA N PN 
Exemple de utilizare : vol. ||, p. 170 


F.4, LOAD-16, DETALIAT 295 


LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 
Grupa 6: Instrucţiuni de restaurare a regiștrilor dubli din stivă (read memory) 


Mnemonica generică : POP Fr 


unde : rr poate fi BC, DE, HL, AF, IX sau IY 
Total instrucțiuni DPI 


Acţiunea : rriow e— (SP) 
SP= SP +1 
rrhigh «— (SP) 
SP= SP+1 
Registrul dublu rr este încărcat din memorie de la adresa specificată 
prin indicatorul de stivă SP. Conţinutul celulei cu adresă inferioară este 


transferat în octetul inferior al lui rr. Indicatorul de stivă este incre- 
mentat cu 2. 


Necesar de memorie : 1 byte pentru BC, D,E, HL sau AF 
2 byte pentru IX sau IY 


Necesar de timp ; 10 (4,3,3) tacți procesor pentru BC, DE, HL sau AF 
14 (4,4,3,3) tacţi procesor pentru IX sau IY 


Structura instrucţiunii 
pentru BC, DE, HL sau AF 
Ea 
pentru IX 
pentru 1Y 


Tipuri de adresare ; destinaţie / sursă 
implicit / indirect 


Memento de cod y POP Tr 


Ch __D1H E1H _F1H 
sc Ţ ve ,. 


Flaguri afectate 


nici unul : [ale[xle[xle ele] pentru BC. DE. HL, IX sau IY 


toate : Le LLEL LII ITEŢI] pentru AF 


Sz  _H _PNGQ 
La execuţia instrucţiunii POP AF registrul F este înscris din memorie 
de la adresa (SP). Astfel toţi biții săi, deci toți indicatorii de condiţii, 
sînt afectaţi. 


Exemple de utilizare : vol. II, p. 149 


296 280 — ANALIZA INSTRUCȚIUNILOR 


LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 7: Schimb de conţinut între regiştri dubli 


Mnemonica : EX DE,HL 


Total instrucțiuni Și. 9 
Acțiunea 3 (et LA 
El 
Conţinutul regiștrilor dubli DE și HL este interschimbat 
Necesar de memorie : 1 byte 


Necesar de timp : 4(4) tacţi procesor 


Structura instrucţiunii : 
byte 


Tipuri de adresare ; destinație / sursă 
implicit / implicit 


Memento de cod - EX DE,HL 


cod : EBH 
Flaguri afectate A nici unul 
e [ex exe lee) 
Ssz HF PN 


Exemple de utilizare : vol. Îl, p 152, p. 199 


LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 8: Interschimbarea regiştrilor primari cu cei secundari 


Mnemonica ş EXX 


Total instrucțiuni îi 3) 


Acţiunea ] B — 
C<— 
D — 
Ea 
H <-> 
L:.— 


Regiștri secundari devin regiștri primari (de lucru) și invers. 
Necesar de memorie : 1 byte 


"Necesar de timp ; 4(4) tacţi procesor 


Structura instrucţiunii : (___că_ 


byte 


Tipuri de adresare : destinaţie / sursă 
implicit / implicit 


Memento de cod : EXX 
cod ; D9H 
Flaguri afectate : nici unul 


e je [x le [x [e Le le) 


TA H PN Cy 
Exemple de utilizare : vol. ||, p. 147 


298 Z80 — ANALIZA INSTRUCȚIUNILOR 


LOAD — 15 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 9: Interschimbarea regiştrilor de stare primari şi secundari 


Mnemonica EX AF,AF' 


Total instrucţiuni cana 


Acţiunea : A A' 
F<-F 


Conţinutul regiștrilor de'stare (AF) primari și secundari este inter- 


schimbat, 
Necesar de memorie : 1 byte 
Necesar de timp : 4(4) tacti procesor 
Structura instrucţiunii : 
Tipuri de adresare ; destinaţie / sursă 


implicit / implicit 


Memento de cod a EX AF,AF' 


cod : O08H 

Flaguri afectate » toate 
LE LILLE LU 
$ Dei Pra Ney 


La execuţia instrucţiunii de interschimbare, toți biții registrului F 
sînt încărcați din registrul secundar P', deci toți indicatorii de condiție 
sînt afectați, 


Observaţie : regiștri AF nu au putut fi cuprinși în instrucțiunea 
de schimb EXX, fiindcă astfel execuţia instrucţiunii 
EXX ar fi provocat o ruptură totală, generînd două stări 
total distincte ale procesorului. Stabilirea unei legături 
între cele două stări ar fi necesitat transferul unor date 
(registri) prin memorie, scăzînd astfel eficienţa instruc- 
țiunii EXX. Neimplicarea regiștrilor AF în instrucțiunea 
EXX permite ca ei să fie folosiți ca și „cutie poștală” 
între cele două stări ale procesorului: pre EXX și 
post EXX. 


Exemple de utilizare : vol. Il, p. 150 


Ed. LOAD-16, DETALIAT 29% 


LOAD — 16 


Clasa 2: Instrucţiuni de transfer de 16 bit 


Grupa 10: Instrucţiuni de interschimbare a regiştrilor dubli cu virful stivei 


Mnemonica generică : 3 X (S P), rr 


unde : rr poate fi HL, IX sau IY 


Total instrucțiuni i Ik l|=B 


Acţiunea : Trlow —— (SP) 
rrhigh — (SP +1) 


Conţinutul registrului dublu rr: este interschimbat cu conţinutul a 
două celule de memorie, adresate prin indicatorul de stivă. Conţinu- 
tul indicatorului de stivă SP rămîne nemodificat, 


Necesar de memorie : 1 byte pentru HL.. 
2 byte pentru IX sau |Y 


Necesar de timp ; 19 (4,3,4,3,5) tacți procesor pentru HL 
23 (4,4,3,4,3,5) tacți procesor pentru IX. sau IY 


Structura instrucţiunii 


CI. pentru HL 
byte 
Cosoi 7 pentru IX 
păntrbr 
byteo byte: 
Tipuri de adresare ; destinaţie / sursă 


indirect / implicit 


Memento de cod "EX (SP)rr 
cod *"E3H 


Flaguri afectate 3 nici unul 


ee xle[x[e [ee] 
SZ H PNG 


Exemple de utilizare : vol. II, p, 199 


300 780 — ANALIZA INSTRUCȚIUNILOR 


LOAD — IDR 


Clasa 3: Instrucţiuni de transfer de blocuri de date 
Grupa 1: Transferuri simple 


Mnemonica generică: LD x (LDD sau LDI) 


unde : x poate fi litera | sau D 


Total instrucțiuni 412 
Acţiunea : LDI (DE) —(HL) 
(load & increment)  DE=DE-+1 
HL=HLÂ+1 
BC=BC-—1 


Conţinutul celulei de memorie adresată prin registrul dublu HL este 
transferat în celula de memorie adresată prin registrul dublu DE. 
Conţinutul registrilor DE și HL este incrementat cu 1, iar cel al 
registrului dublu BC decrementat cu 1, 


LDD (DE) —(HL) 
(load & decrement) DE=DE-—1 
BC=BC—1 
dem, cu deosebirea ca indicatorii de adresă DE și HL sînt decre- 
mentați. 
Necesar de memorie -; 2 byte 
Necesar de timp 4 16.(4,4,3,5) tacţi procesor 
Structura instrucţiunii 
Tipuri de adresare ; destinaţie / sursă 
indirect / indirect 
Memento de cod E (LDD sau LDI) 


AO H A1 ANAR H A3 HA4 HA5SHA6 HA7 H AB HA9 AAA 8 H Ac HADHAEHAFH 


| tata 4 250 dada ne 


no pete 
ok 


CPI INI QUTI 
Flaguri afectate = rupe N 


- |: [XlolxL: lol: 
SzZ H PNC 


P=0 dacă după efectuare BC=0 
P=1 dacă după efectuare BC240 


Exemple de utilizare : vol. Il, p. 190 


E.5. LOAD-IDR, DETALIAT 301 


LOAD — IDR 


Clasa 3: Instrucţiuni de transfer de blocuri de date 


Grupa 2: Transferuri multiple 


Mnemonica generică _: LD i R (LDDR sau LDIR) 


unde : x poate fi litera | sau D 
Total instrucțiuni șI 


Acţiunea . 


+ LDIR — load, increment, repeat 
— LDDR — load, decrement, repeat 


Instrucţiunea transferă un bloc de date de lungime egală cu BC din- 
tr-o zonă de memorie în alta Blocul sursă începe la adresa specificată 
de registrul HL. Blocul destinaţie începe la adresa specificată de DE. 
Transferul are loc în sens crescător (LDIR) sau descrescător (LDDR). 


Necesar de memorie : 2 byte o So 


Necesar de timp „421 (4,4,3,5,5) tacţi procesor dacă BCz+0 
16 (4,4,3,5) tacți procesor dacă BC=0 


Structura instrucţiunii 


Tipuri de adresare ;. destinaţie / sursă 
indirect / indirect 
x 
Memento de cod - LD R (EDO S0UEOIR) 
BOHB! HB2HB3HBLHB5Ha36HB7HB8Ha9HBAHBBHBCHBDHBEHBF-H 
7039093: 074 J 77 0707070 "00.0 
stotaaă, aczaaa DD î aa ecera ceata 
95%0to% statata stea datate? „Tetete! 
CPIR INIR OTIR CPDR INDR OTDR 
Flaguri afectate :H,P, N, toate resetate 
|: IXlolxlolo-) 
SF PN Cy 
Exemple de utilizare : vol. Il, p. 175 


302 Z80 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 1: Aritmetice —- Adunarea simplă a regiştrilor 


Mnemonica generică : ADD A, r 


unde : r poate fi B, C, D,E, i, L sau A 
Total instrucțiuni NI ac 0 al 


Acţiunea , Ă = A + p 


Conţinutul registrului r este adunat cu cel al registrului A, rezultatul 
obţinîndu-se în registrul A. Conţinutul registrului r nu se modifică, 


Necesar de memorie : 1 byte 


Necesar de timp : 4 (4) tacţi procesor 
Se execută cu suprapunere de cicluri mașină, fizie necesită 5 tacți. 
AR/LOG ADD ADD 
Structura instrucţiunii CNA CI aia 
byte 
unde : r2rirO reprezintă codul pe 3 bit al regiștrilor interni 
000 —B — 
001 —C 101— 
010-D 110 
011 -£ 111=A4A 
Tipuri de adresare op! | op2 


implicit / implicit 


Codul a se “Eh îngu nînd numerele aferente rindului și coloanei 
în care se află instrucțiunea căutată. 


Exemplu : ADD A,H 80H + 4 = 84H 
Flaguri afectate ; toate 
le [x [vlol ti 
H P N Cy 
flagul P/V indică depășirea - flagul N=0 indică adunarea efectuată 
Exemple de utilizare : vol. Il, p. 197 


E.6. AR/ LOG-B, DETALIAT 


ARLLOG —8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 2: Aritmetice — Adunarea regiștrilor cu adăugarea transportului 


Mnemonica generică : ADC A,r (add with carry) 


unde : r poate fi B, C, D,E, H, Lsau A 
Total instrucțiuni i E i pr 


Acţiunea A=A+r+ Cy 


Este o adunare dublă : la conținutul iniţial al lui A se adaugă conți- 


nutul registrului r și al flagului carry (transport). Rezultatul se obține 
în A. Conţinutul registrului r rămîne neafectat. 


Necesar de memorie : 1 byte 
Necesar de timp : 4 (4) tacţi procesor 
Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi. 
AR/LOG 
Structura instrucţiunii : ([ToŢoŢo[1 [ro]ra [ra 
byte | 
unde : r2r1r0 reprezintă codul pe 3 bit al regiștrilor interni 
000— B 100—H 
001 —C 101—L 
010—D 110 
011 —E 111—A 
Tipuri de adresare 3 op /op2 


implicit / implicit 

Memento de cod : : ADC A PF 
100 af an aat e la mb, BEA „aorezocar 
are APS PI i 1 iei 
ANDr ADH E ara pote al AM+XgR n 


II * ID * (Iv MID val Do ia -. 


Codul ă ep XE îrisumind ae Sati Cndului și coloanei 
în care se află instrucțiunea căutată, 


Exemplu: ADC A,D 80H + A = 8AH 
Flaguri afectate ; toate 


x [e |xlvloLt! 


cd H PN Cy 
flagul P/V indică depășirea flagul N=0 indică adunarea efectuată 
Exemple de utilizare 


304 780 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 3: Aritmetice — Scăderea simplă a regiştrilor 


Mnemonica generică  : SUB r 


unde: r poate fi B, C, D,E, H, Lsau A 
Total instrucțiuni Pe ae "aa late 109, 
Acţiunea *A=A-—r 


Conţinutul registrului r se scade din conţinutul registrului A. Rezul- 
tatul se obține în registrul A. Conţinutul registrului r rămîne nemodi- 


ficat, 
Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacți procesor 
Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi. 
AR/LOS SUB 
Structura instrucţiunii : i ŢoŢoŢi orare 
byte 
unde : r2r1r0 reprezintă codul pe 3 bit al regiștrilor interni 
000—B 100—H 
001 —C 101 —L 
010—D 110 
011 —E 111—A 
Tipuri de adresare - op /op2 
implicit / implicit 
Memento de cod : SUB r 
pipi F 
msn EPEERPI co MIDI 
SUB r 90H+ aia Ă/S 4 ) X XPU le SBC A r 
. Y ] LĂ 5 XX ZIP XI | PA N, 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată, 


Exemplu: SUB B 90H + 0 = 90H 
Flaguri afectate ; toate 
e |: x [x lv ŢY] 
sz H PNOy 
flagul P/V indică depășirea ZE flagul N=1 indică scăderea efectuată 


Exemple de utilizare 


20 — Totul despre microprocesurul Z 80 vol. 1 și 2 


305 


AR/LOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bii 


Grupa 4: Aritmetice — Scăderea regiștrilor cu scăderea transportului 
- SBC A,r (subtract with carry) 


«unde : r poate fi B, C, D,E,H,Lsau A 


Mnemonica generică 


Total instrucțiuni SULA ea je 


„A=Azr = Cy 


Acțiunea 


Este o scădere dublă. Din conținutul iniţial al regisirului A se scade 
conținutul registrului r și conținutul indicatorului de transport. Con- 
ținutul _registrului r rămîne nemodificat, 


Necesar de memorie : 1 byte 


Necesar de timp ; 4 (4) tacţi procesor 
Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi. 


AR/LOG SBC 
po pf 


Structura Instrucțiunii : "ŢoTSfŢrzrTre] 


unde : r2r1r0 reprezintă codul pe 3 bit al regiștrilor interni 


000—B 100—H 
001 —C 101 —L 
010—D 110 
011 —E 111 —A 
Tipuri de adresare : opl /op2 


implicit / implicit 
Memento de cod ş SBC Ar 


E TR și AAoforigiat 
ARD ic Cald ca tza 9090 tă ou 
arm EPA LIADĂ e e bah 
iu Pa! 0, 220 20! 89 0 Act cu 0 0 a 20, Qa 
RF OY SAV/N SK SAAR SALAR AA K XX 
So RSI DOES IO 


306 Z80 — ANALIZA INSTRUCȚIUNILOR 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 


Exemplu : SBC A,E 90H + BH = 9BH 


Fiaguri afectate ; toate 


x xl 


5. € H PN Cy 
flagul P/V indică depășirea flagul N=1 ingică scăderea efectuată 


Exemple de utilizare 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 5 : Logice — Operația ŞI cu regiştri 


Mnemonica generică . AND r 


unde : r poate fi B,C, D,E, H, Lsau A 
Total instrucțiuni re pda DE ZA 


Acţiunea A AAr 


Se execută o funcție ȘI logic între conținutul registrului A și con- 
ținutul registrului r. Operația se execută între 2 biți fiecare avînd 
aceeași poziție semnificativă. Rezultatul se obține în registrul A. Con- 
ținutul registrului r rămîne nemodificat. 


Rezultatul operației ȘI este 1, dacă și numai dacă ambii biți au avut 
valoarea logică 1. În rest rezultatul este O. 


Necesar de memorie : 1 byte 
Necesar de timp 2 4 (4) tacţi procesor 
Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi, 
AR/LOG AND 
pa 


rr — 
Structura instrucţiunii :  [1[o0[1 [oo [rz[ri[ral 
byte 


unde : r2r1r0 reprezintă codul pe 3 bit al regiștrilor interni 


000—B 100-—H 
001—C 101 —L 
010—D 110 

011 —E 111 —A 


308 2830 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare - op1 | op2 
implicit / implicit 


Memento de cod : AND r 
i N 000 AD ti ai 
== POPA 
AND 1 ADH» i 


ma r Bon. |Ă 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 


Exemplu : AND A A0H + 7 = A7H 
Fiaguri afectate ; toate 
L: |: [x]: [xle]o [o] 
S Z LH PIN Cy 
SIT 


flagul P/V indică paritatea 


Exemple de utilizare : vol. Il, p. 174 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 6: Logice — Operația SAU EXCLUSIV cu regiştri 


Mnemonica generică :XOR r 


unde : r poate fi B,C,D,E, H, Lsau A 
Total instrucţiuni a Pa. 


Acţiunea :A-AVr 


Se execută o funcție SAU EXCLUSIV între conținutul registrului 
A şi conţinutul registrului r. Operația se execută pe cîte 2 biţi, 
fiecare avînd aceeași poziție semnificativă. Rezultatul se generează în 
registrul A. Conţinutul registrului r rămîne nemodificat. 


Rezultatul operației SAU EXCLUSIV este 1, dacă și numai dacă cei 
doi biţi au avut valori diferite. In caz de egalitate rezultatul este 0. 


Necesar de memorie : 1 byte 
Necesar de timp : 4 (4) tacţi procesor 


Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi. 


pei eee 


Structura instrucţiunii : CŢoȚIŢSTi zriltol - 
byte 


AR/LOG XOR 
po 


unde : r2rîrO reprezintă codul pe 3 bit al regiștrilor interni 


000—B ”100—H 
001 —C 101 —L 
010—D 110 

011 —E 111—A 


310 Z80 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare : opi / op2 
implicit / implicit 


Memento de cod : XOR r 
Do, Mia Mu COTĂ DN e 
sn me it A 11 Adana na 


220 


Codul dorit se obține însumînd numerele aferente rîndului şi coloanei 
în care se află instrucțiunea căutată, 


Exemplu : XOR H AOH + CH = ACH 
Flaguri afectate ; toate 
:L.-Ix [o x lo 0, 
H PN Cy 


flagul P/V indică paritatea 


Exemple de utilizare : vol. ||, p. 177 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 7: Logice — Operația SAU cu regiștri 
Mnemonica generică _: OR Li 

unde : r poate fi B, C, D. E, H, Lsau A 
Total Instrucţiuni AD de | 0, 
Acţiunea : A=AVI 


Se execută o funcție SAU logic între conţinutul registrului A și con- 
ținutul registrului r. Operația se execută pe cîte 2 biți, fiecare avînd 
aceeași poziție semnificativă, Rezultatul se generează în registrul A. 
Conţinutul registrului r rămîne nemodificat. 


Rezultatul operației SAU este 1, dacă oricare din cei doi biți are 
valoarea 1. Rezultatul este 0 dacă ambii biți au fost 0. 


Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacţi procesor 


Se execută cu suprapunere de cicluri mașină. Fizic necesită $ tacți. 


AR/LOG OR 


PA, 
Structura instrucţiunii : [1 [o [n [iŢolrz[r[rgl 


byte 


unde ; r2rîr0 reprezintă codul pe 3 bit al regiștrilor intern! 
000— B 100—H 
001 —C 101—L 
010—D 110 
011—E£ 111—A 


312 780 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare : copi /opz 
implicit / implicit 


Memento de cod ş OR r 
PTD iti 10 099.970, 040 0399.99 ta 
mr sote |e |o [e |n [e 33 + XXV AXĂ Apor 


Codul dorit se obține însumînd numerele aferente rîndului+şi coloanei 
în care se află instrucțiunea căutată, 


Exemplu : OR C BOH +1 = BIH 
Flaguri afectate ; “toate 
|: [xlo|x Je [o Jo! 
sZ H PNCy 


flagul P/V indică paritatea 


Exemple de utilizare : vol. Il, p. 168, p. 188 


ARJLOG. — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 8: Logice — Comparaţia acumulatorului cu regiştri 


Mnemonica generică _: CP r 


unde : r poate fi B, C, D,E, H,L,. sau A 
Total instrucțiuni :-7*x41= 


Acţiunea  A=—r 


Se efectuează o scădere. Conţinutul registrului r se scade din conți- 
nutul registrului A. 
Operația este identică cu cea de la SUB r cu deosebirea că nu se 
generează rezultat. Deci conținutul regiștrilor A și r rămîne nemodi- 
ficat, Se poziţionează indicatorii de condiție. 
Exemplu : dacă A=r atunci flagul zero va fi înscris: Z=1 
Necesar de memorie  : 1 byte 
Necesar de timp ; 4 (4) tacți procesor 
Se execută prin suprapunere de cicluri mașină. 
Fizic necesită 5 tacți. 
AR/LOG CP 
—=— 


Structura instrucţiunii : CIOT [e Teze] 


unde : r2rîrO reprezintă codul pe 3 bit al regiștrilor interni 


000 — B 100—H - 010—D 110 
001 —C 101 —L 011 —E 111—A 
Tipuri de adresare : op1 / op2 
implicit / implicit 
Memento de cod i + CP r 
: 2 Fr Da RE A_B BL: D 
sarea EET ital Sa atena 
SuB r so N /| 90H+SBC Ar 
AND r ADH+ și NI AO, XgR! 
EI ea pe 


Codul dorit se obține însumînd numărul aferent rîndului şi coloanei 
în care se află instrucțiunea căutată. 


Exemplu : CP L BOH + DH = BDH 
Flaguri afectate : toate 


Se Z „H pP Cy 
flagul P/V indică depășirea flagul N=1 indică scăderea efectuată 
Exemple de utilizare : vol. II, p. 154 


314 Z80 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 9: Aritmetice — Adunare simplă cu locaţii de memorie 


Mnemonica generică : ADD) A,(mem) 


unde : mem poate fi HL, IX+IND, IY+IND 
Total instrucțiuni cit NE E: e: 


Acţiunea : A= A+ (mem) 
Conţinutul celulei de memorie adresată prin conținutul registrului 
dublu este adunat cu conţinutul registrului A. Conținutul celulei de 
memorie implicată în operație nu se schimbă. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+IND sau IY+IND 
Necesar de timp ; 7 (43) tacţi procesor pentru HL 
19 (4,4,3,5,3) tacți procesor pentru IX+IND sau 
IY+IND 


Se execută cu suprapunere de cicluri mașină: M2 pentru HL și MS 
pentru IX+IND sau IY-+IND. Necesită fizic 4 tacți procesor. 


Structura instrucţiunii 


AR/LOG_ ADD mem 
[1 [o [o fo [o [1] pentru HL 
byte 
CEI pentru IX--IND 
pentru IY-+IND 


byte 0 byte 1 byte 2 


Tipuri de adresare : op1 / op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX-+-IND sau IY+IND 


Memento de cod i ADD A.(mem) 


cod : -86H 
Flaguri afectate ; toate 
SE X |: [x |v lo[i] 


H e Is bică 
flagul P;V indică debăşitta A i flagul N=0 indică adunarea efectuată 


Exemple de utilizare 
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ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 10: Aritmetice — Adunare cu adăugarea transportului (memorie) 


Mnemonica generică : ADC A,(mem) 


unde : mem poate fi HL, IX+IND sau IY+IND 
Total instrucțiuni > AX 13 


Acţiunea : A A+ (mem) Cy 


Se execută o adunare dublă : conținutul celulei de memorie, adresată 
prin conținutul registrului dublu, se adună la conținutul registrului 
A și se adună conținutul indicatorului de transport (carry). 
Rezultatul se obține în registrul A. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+-IND sau IY+IND 
Necesar de timp ; 7 (4,3) tacţi procesor pentru HL 
19 (4,4,3,5,3) tacți procesor pentru IX-+-IND sau 
IY+IND 


Se execută cu suprapunere de cicluri mașină: M2 pentru HL și M5 
pentru IX+IND sau IX+IND necesită fizic 4 tacți procesor, 


Structura instrucţiunii 
pentru HL 
pentru IX+IND 
pentru IY+IND 


byte 0 byte 1 byte 2 
Tipuri de adresare 2 op! /op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX-+IND sau IY+IND 


Memento de cod : ADC A/(mem) 
cod : 8EH 
Flaguri afectate ; toate 
MIEIAEICACIIA 
Sz H PN Cy 


flagul P/V indică depășirea i Mea flagul N=0 indică adunarea efectuată 


Exemple de utilizare : vol. Il, p. 177 


316 70 — ANALIZA INSTRUCȚI. NILOI. 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 11: Aritmetice — Scădere simplă cu locaţii de memorie 


Mnemonica generică : SUB (mem) 


unde : mem poate fi HL, IX-+IND, IY+IND ' 
Total instrucţiuni ci Da pe ici 


Acţiunea vf = Ang (mem) 


Conţinutul locației de memorie adresată prin registrul dublu este 
scăzut din conținutul acumulatorului A. Rezultatul se obține în regis- 
trul A. Conținutul celulei de memorie implicată în operație nu se 


schimbă. 
Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+IND sau IY-+IND 
Necesar de timp : 7 (4.3) tacţi procesor pentru HL 
19 (4,4,3,5,3) tacţi procesor pentru IX-+-IND sau 
IY+IND 


Se execută cu suprapunere de cicluri mașină : M2 pentru HL şi M5 
pentru IX+IND sau IY+IND necesită fizic 4 tacți. 


Structura instrucţiunii 
ARALOG SUB „nem 
e TelepferiTe pentru HL 


pentru IX+IND 


=== pentru |Y+IND 
byte? 


Tipuri de adresare : opt / op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX+IND sau IY+IND 


Memento de cod : SUB (mem) 
cod + 296H 
Flaguri afectate ; toate 


xx lvl 


sz H PNG 


flagul P/V indică depășirea flagul N=1 indică scăderea efectuată 
Exemple de utilizare 


F.6. AR/ LOG-8, DETALIAT 317 


AR/LOG—8 


Clasa 4 : instrucțiuni arltmetice/logice pe 8 bit 


Grupa 12: Aritmetice — Scădere cu scăderea transportului (memorie) 


Mnemonica generică : SBC A,(mem) 


unde : mem poate fi HL, IX+IND, IY+IND 
Total instrucţiuni - : 3x1=3 


Acțiunea ':A= A 14) (mem) aci Cy 
Se efectuează o scădere dublă : conținutul celulei de memorie adre- 
sată prin registrul dublu și conținutul indicatorului de transport 
(carry) se scad din conținutul registrului A. Rezultatul se obține în 
registrul A. Conţinutul celulei de memorie implicată în operaţie nu 


se schimbă. 
Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX+IND sau IY--IND 
Necesar de timp : 7 (4,3) tacţi procesor pentru HL. 


19 (4,4,3,5,3) tacți procesor pentru IX+IND sau 
IY+IND 


Se execută cu suprapunere 'de cicluri mașină: M2 pentru HL și M5 
pentru IX+.IND sau IY+IND necesită fizic 4 tacţi procesor. 


Structura Instrucțiunii : 


AR(LOG_ SBC_ mem 


pentru HL 
Îi pentru IX-+IND 
pentru IY+IND 
Tipuri de adresare : opt /op2 


implicit / indirect pentru HL 
implicit / indexat pentru IX+IND sau IY+IND 


Memento de cod : SBC A,(mem) 
cod "I9EN 


Flaguri afectate ; toate 
Le ixltixe [| 
SI iH PP. Cy 
flagul P/V indică depăşirea flagul N=f indică scăderea efectuată 


Exemple de utilizare : vol. il, p. 178 


318 
780 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG —-8 


Clasa 4: instrucțiuni aritmetice/logice pe 8 bit 


Grupa 13: Logice — Operația SI cu locaţii de memorie 


Mnemonica generică : AND (mem) 
unde : imem poate fi H!, IX+IND sau IY+IND 


Total instrucţiuni > 3x13 


Acţ iunea : A = AA (mem) 


Se efectuează o funcție SI logic între conținutul registrului A și con- 
ținutul celulei de memorie adresată prin registrul dublu. Operația 
se execută pe cite 2 biți, fiecare avînd aceeași poziție semnificativă. 
Rezultatul se obține în registrul A. Conţinutul celulei de memorie 
implicate în operaţie nu se schimbă. 


Rezultatul operaţiei SI este 1, dacă și numai dacă ambii biți au avut 
valoarea logică 1. În rest rezultatul este O. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX+IND sau IY-+-IND 


Necesar de timp : 7 (4,3) tacţi procesor pentru HL 
19 (4,4,3,5,3) tacți procesor pentru IX+IND sau 
IY+IND 


Se execută cu suprapunere de cicluri mașină: M2 pentru HL şi M5 
pentru IX-+IND sau IY+IND necesită fizic 4 tacți procesor. 


Structura instrucţiunii 
(& AND PR ul 
ARLOG_AND_ 


CIEIGCIEIEIEI CI pentru HL 


byle 


De Da ae CS] pentru IX+IND 
CEI Cosa CE pentru IW+IND 


byte 0 byte 2 
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Tipuri de adresare ş opi / op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX+IND, sau IY+IND 


Memento de cod : AND (mem) 
cod :  A6H 
Flaguri afectate  : toate 
: |: [x[n [x[e]o Lo! 
Sz HN PNCy 


flagul P/V indică paritatea 


Exemple de utilizare 


ARLLOG — 8 


Clasa 4 : Instrucţiuni aritmetice /logice pe 8 bit 


Grupa 14: Logice — Operația SAU EXCLUSIV cu locaţii de memorie 


Mnemonica generică : XOR (mem) 


unde : mem poate fi HL, IX+IND, IY+IND 
Total instrucțiuni Ce Lica bl 


Acţiunea : A=A7 (mem) 


Se efectuează o funcție SAU EXCLUSIV între conţinutul registrului 
A și conținutul celulei de memorie adresată prin registrul dublu. 
Operația se execută pe cîte 2 biți, fiecare avînd aceeași poziție sem- 
nificativă. 

Rezultatul se obține în registrul A. Conţinutul celulei de memorie 
implicată în operație nu se schimbă. 


Rezultatul operației SAU EXCLUSIV este 1 dacă și numai dacă cei 
2 biţi au avut valori diferite. În caz de egalitate rezultatul este O. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+-IND sau IY+IND 
Necesar de timp : 7 (4,3) tacți procesor pentru HL 
19 (4,4,3,5,3) tacţi procesor pentru IX+-IND sau 
IY-+IND 


Se execută cu suprapunere de cicluri mașină. 'M2 pentru HL și M5 
pentru IX+IND sau IY+IND necesită fizic 4 tacți procesor. 


Structura instrucţiunii 


ARILOG XAR__ mem 
(2 [o [n [o [1 [n [n lo] pentru HL 
byte 
pentru IX + IND 
Cea ien) pentru IY+IND 
byte 0 byte 1 byte 2 


21 — Totul despre microprocesorul Z 80 vol. 1 şi 2 321 


“Tipuri de adresare 3 opi | op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX-|-!ND sau IY-+-IND 


Memento de cod - XOR (mem) 
cod ;  AEH 
Flaguri afectate ; toate 


te eISB) 
Ss z H PN Cy 
flagul P/V indică paritatea 


Exemple de utilizare 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 15: Logice -- Operația SAU cu locaţii de memorie 


Mnemonica generică  : OR (mem) 


unde : mem poate fi HL, IX+IND, IY+IND 
Total instrucțiuni sas = 


Acţiunea ; A = A (mem) 


Se execută o funcție SAU logic între conținutul registrului A și 
conținutul celulei de memorie adresată prin registrul dublu. Operația 
se execută pe cîte 2 biți, fiecare avînd aceeași poziție semnificativă. 
Rezultatul se generează în A. Conţinutul celulei de memorie implicată 
în operație nu se schimbă. 


Rezultatul operației SAU este 1, dacă oricare din cei 2 biţi are valoa- 
rea 1. Rezultatul este O doar dacă ambii au fost 0. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX+IND sau IY+IND 
Necesar de timp : : 7 (4,3) tacți procesor pentru HL 
19 (4,4,3,5,3) tacți procesor pentru |IX+IND sau 
IY+IND 


Se execută cu suprapunere de cicluri mașină: M2 pentru HL și M5 
pentru IX+4IND sau IY+IND necesită fizic 4 tacți procesor. 


Structura instrucţiunii 


ARJLOG_9R__ mem 
[o lol Jo] pentru HL 
. byte 
[costin] pentru IX+IND 
[o pentru IY+IND 
byte byte 1 byte 2 
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Tipuri de adresare - opt /op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX+IND sau IY+IND 


Memento de cod : OR (mem) 
cod : B6H 
Flaguri afectate : toate 
+] :|x]o[x[e o [o] 
SzZ HN PNCy 


flagul P/V indică paritatea 


Exemple de utilizare 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 16: Logice — Comparaţia acumulatorului cu locaţii de memorie 


Mnemonica generică : CP (mem) 


unde : mem poate fi HL, IX+IND, IY+IND 
Total Instrucţiuni Pg] 3 


Acţiunea : A— (mem) 


Se efectuează o scădere. Conţinutul celulei de memorie adresată prin 
conținutul registrului dublu. se scade din conținutul registrului A. 
Operația este similară cu cea de la SUB (mem), cu deosebirea că 
nu se generează rezultat. Deci conținutul registrului A și al celulei 
de memorie implicată în operaţie nu, se schimbă. Se poziţionează indi- 
catorii de condiţie. 2 
Exemplu : dacă A < (mem) atunci flagul carry va fi înscris: Cy=1. 
Necesar de memorie : 1 byte pentru HL 
i 3 byte pentru IX-+-IND 'sau IY+IND 
Necesar de timp ; 7 (4,3) tacți procesor pentru HL 
19 (4,4,3,5,3) tacți procesor pentru IX+IND sau 
IY+IND 
Se execută cu suprapunere de cicluri mașină: M2 pentru HL și M5 
pentru IX+IND sau IY+IND. Necesită fizic 4 tacți procesor. 
Structura instrucţiunii : 


ARADG CP mem 


CE TRIER pentru Fl 


byte 
pentru. IX+kIND 
TI sea e pentru IY+IND 
Tipuri de adresare i opi / op2 


implicit / indirect pentru HL 
implicit / indexat pentru IX-+-IND sau IY+IND 


Memento de cod : CP (mem) 


cod : BEH 
Flaguri afectate : CITITI DIV 
ȘIZ H PN Cy 
flagul P/V indică depășirea = flagul N=1 indică scăderea efectuată 


Exemple de utilizare 


E.6, AR/ LOG-8, DETALIAT 325 


ARJLOG — 8 


Clasa 4: Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 17: Instrucţiuni aritmetice și logice imediate 


Mnemonice posibile : ADE Pai AND n 
ADC An XOR n 
SUB n ,, OR n 
SBC An CP n 


unde : n este un număr [0,255] 


Total instrucțiuni Bia 1 ag 
Acţiunea : A = Ă op n 


unde : — op poate fi ADD, ADE, SUB, SBC, AND, XOR sau OR 
Oricare din cele șapte operaţii enunțate se efectuează între conţinutul! 
registrului A și numărul n. 
Rezultatul se generează în registrul A. 
— op CP:A--n; în cazul operaţiei de comparare. 
Necesar de memorie : 2 byte 


Necesar de timp : 7 (4,3) tacți procesor 
Se execută cu suprapunere de cicluri mașină : M2, necesită fizic 4 
tacți procesor. 


Structura instrucţiunii : În aa 
byte O byte 1 


Tipuri de adresare - E op1 / op2 
implicit / imediat 


Memento de cod „CSN _CEH D6H DEH __E6H EEH F6H FEH 
neo Ţaoc Ţsue Ţsae mo Ţoea [se Ţee | 


Flaguri afectate :. toate 
* |? [x]* [x [e [o Jo! LE jEjxjo|x'Plo 9) 
5SZe N PN Ssz 1.  PNCy 
AND XR, JR | 
|! |xltlxlvlo [!| MEDIEI IEI CIA 
SzZz H PNG SzZ HN PNG 
ADD , ADC SUB,SBC, CP 


Exemple de utilizare : vol. ||, p. 155, p. 174 


326 Z80 — ANALIZA INSTRUCȚIUNILOR 


ARILLOG — 8 


„Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 18 : Incrementarea regiștrilor simpli 


Mnemonica generică : INC Lui 


unde : r poate fi B, C,D, E, H,Lsau A 


Total instrucțiuni pe 7 
Acţiunea :r=r+1] 
Conținutul registrului r este incrementat cu 1. 
Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacţi procesor 


Structura instrucţiunii : [OȚO[ra|rilfol 1100] 
byte 


unde : r2rîr0 este codul pe 3 bit al regiștrilor interni 
000 —B 100.-H 


001 —C 101 —L 

010-D 110 

011 —E 111—A 
Tipuri de adresare : implicit 
Memento de cod : INC r 


252502] 
Le je Le | a: 
1909.90 


Flaguri afectate ; „toate cu excepţia lui carry 
Li txt [x]vlo Le! 
Ci ADOBE 9 Madi imi 
flagul P/Y indică depășirea d - „ flagul N=0 indică adunarea efectuată 


Exemple de utilizare : vol, ||, p. 179 


56. AR/ LOG-8, DETALIAT 327 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 19: Decrementarea regiștrilor simpli 


Mnemonica generică : DEC r 


unde : r poate fi B, C, D,E, H, Lsau A 
Total instrucţiuni A i d, o A 
Acţiunea :r=r-1 

Conţinutul registrului r este decrementat cu 1. 
Necesar de memorie : 1 byte 


Necesar de timp ; 4 (4) tacți procesor 


Structura instrucţiunii : [O LO 72] 4]79]1]0[1] 
byte 


unde ; r2rîrO este codul pe 3 bit al regiștrilor interni 
000—B 100—H 
001 —C 101 —L 


010—D 110 
011—E 111—A 
Tipuri de adresare : implicit 


Memento de cod DEC r 


054 _0Du 15 10 25 20 354 30 


re ama tav, 


Flaguri afectate ; toate cu excepția lui carry 


L: xxl le! 


Sz HN PN Cy 
flagul P/V indică depășirea flagul N=1 indică scăderea efectuată 


Exemple de utilizare ; vol. Il, p 179 


328 2750 — ANALIZA INSTRUCȚIUNILOR : 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 20: Incrementarea locaţiilor de memorie 


Mnemonica generică : INC (mem) 
unde : mem poate fi HL, IX+IND, IY+IND 


Total instrucțiuni e ph e 


Acţiunea : (mem)= (mem) +1 


Conţinutul celulei de memorie avînd adresa specificată prin conţinu- 
tul registrului dublu este incrementat cu 71. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+-IND sau IY-+IND 


Necesar de timp ; 11 (4,4,3) tacţi procesor pentru HL 
23 (4,4,3,5,4,3) tacți procesor pentru IX-+-IND sau 
IY+IND 


Ciclul M4 este un ciclu intern pur. 


Structura instrucţiunii 


(SIT: TTer" Iele) 
CIEIEIE3EIEICIE) petele iii 
pentru IX-+IND 
pentru IY+IND 
byte 0 byte 1 byte 2 
Tipuri de adresare : indirect pentru HL 
indexat pentru IX-+IND sau IY+IND 
Memento de cod : INC (mem) 
cod : 34H 
Flaguri afectate ; toate cu excepția lui carry 
e | [x[i lxlvlo le) 
S2z H PN Cy 
flagul P/V indică depășirea sad iai flagul N=0 indică adunarea efectuată 


Exemple de utilizare : vol. Îl, p 182 


E.6. AR/ LOG-8, DETALIAT 


AR/L OG - 


09 


Clasa 4 : Instrucţiuni 'aritmetice/logice pe 8 bit 


Grupa 21 : Decrementarea locaţiilor de memorie 


Mnemonica generică : DEC (mem) 
unde : mem poate fi HL, IX+IND, IY+IND 

Total instrucțiuni pe 9 tisă 

Acţiunea :: (mem) ( mem) — 7 


Conţinutul celulei de memorie adresată prin conținutul registrului 
dublu este decrementat cu 1. 


Necesar de memorie : 1 byte pentru HL 
3 byte pentru IX-+-IND sau IY+IND 


Necesar de timp ; 11 (4,4,3) tacți procesor pentru HL 
23 (4,4,3,5,4,3) tacți procesor pentru IX+IND sau 
IY+IND. Ciclul M4 este un ciclu 
intern pur. 


Structura instrucţiunii 


Lo Jon [+ o[* lo[+] 
byte pentru HL 


CSI Pata CI pentru IX+IND 
Dia CI Aa IE AP IV IND 


byte 0 byte 


Tipuri de adresare : indirect pentru HL 
indexat pentru IX+IND sau IY+IND 


Memento de cod : DEC (mem) 
cod : 35H 
Flaguri afectate : toate cu excepția lui carry 
e De[ixve] 
PN Cy 
flagul P/V indică depășirea isi flagul N=1 indică scăderea efectuată 


Exemple de utilizare : 


330 780 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 22: Complementarea față de 1 (acumulator) 


Mnemonica - CPL 


Total instrucțiuni zi 


Acţiunea : A = A 


Conţinutul acumulatorului A este complementat față de 1. Rezultatul 
se obține în registrul A. 


Necesar de memorie : 1 byte 


Necesar de timp ; 4 (4) tacţi procesor 


Structura instrucţiunii ; 
byte 


Tipuri de adresare : implicit 
Memento de cod Ş 2 4 
cod i. aPii 
Flaguri afectate ; H și N devin 1 
Le je x [1 |xle [+ le) 
S 2 Pay 
Exemple de utilizare : vol. Il, p. 145 


E.6. AR/ LOG-8, DETALIAT 331 


ARILOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 23: Complementarea față de 2 (acumulator) 


Mnemonica A în k G 


Total instrucțiuni sia) 


Acţiunea : A=O-A 


Conţinutul acumulatorului A este complementat față de 2. Rezul- 
tatul se obţine în acumulatorul A. 


Necesar de memorie : 2 byte 


Necesar de timp : 8 (4,4) tacţi procesor 
: 
Structura instrucţiunii : Ce ir î 
Tipuri de adresare : implicit 
Memento de cod : NEG 
cod : 4M4H 
Flaguri afectate : toate 
MIEI MEIER 
% 2 H P N Cy 
P=1 dacă A a fost 80H ti Cy=1 dacă A a fost 0 


Exemple de utilizare 


332 730 — ANALIZA INSTRUCȚIUNILOR 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 24: Ajustarea BCD a acumulatorului 


Mnemonica : DAA 


Total instrucțiuni PY, 
Acțiunea ; 
Dacă se folosește una din instrucțiunile ADD, ADC, INC, SUB, 
SBC, DEC sau NEG instrucțiunea DAA ajustează sub forma BCD 
conținutul registrului A. Se presupune că numerele implicate în ope- 
rația premergătoare au fost deja numere BCD. Pentru a realiza funcția 
dorită se adaugă -+-6, +60, +66, —6, —60 sau —66 la conținutul 
acumulatorului în funcție de starea flagurilor C, N și H. Această 
instrucțiune impune existența flagurilor N și H. 

Redăm tabela de * operaţii cele în [13, p. 236] 


E eriar inferior 


p 
«i 
2 
w 


=== 000000 

Da oo|ocoP>opoeo 
SRI e 3 Sea 

N N O|U PoNNNPO 

DOoNOo|o POE POoEoP 

NP NPIWNoWNoWT 


Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacţi procesor 
Structura instrucţiunii : 
Tipuri de adresare i implicit 
Memento de cod - DAA 
cod ; 27H 

Flaguri afectate ; toate cu excepţia lui N 

E A e pb 

H PN 


flagul P/V indică paritatea 


Exemple de utilizare : vol. Il, p. 177 


E.6. AR/ LOG-8, DETALIAT 


ARJLOG — 8 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 


Grupa 25: Rotirea acumulatorului „,cu” carry 


Mnemonica generică -R> CA | RLCA sau RRCA) 


unde : x poate fi litera L sau R 


Total instrucțiuni nu 4 Îsz2 
A A 
7 35 pa oii 
RLCA RRCA 
Acţiunea : RLCĂ RRCA 


Conţinutul registrului A este depla- Conţinutul registrului A este depla- 


sat cu o poziție la stînga. sat cu o poziție la dreapta. 
Bitul 7 inițial se mută atît în Cy cît  Bitul O iniţial se mută atît în Cy cît 
şi pe poziția bit 0. și pe poziția bit 7. 

Necesar de memorie : 1 byte 

Necesar de timp 4 (4) tacţi procesor 


Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacți. 


Structura instrucţiunii : 
byte 
Tipuri de adresare : implicit 
Memento de cod :R> CA RLCA sau RRCA 
RLCA RRCA 
cod  "O7Fi OFH 
Flaguri afectate 5 Gyil șiabl 
ARICI ECU 
PN Cy 
Exemple de utilizare : i II, p. 186 


334 780 — ANALIZA INSTRUCȚIUNILOR 


Clasa 4 : Instrucţiuni aritmetice/logice pe 8 bit 
Grupa 26 : Rotirea acumulatorului „prin” carry 


: a Sp 
Mnemonica generică _: |. Pi (RR 


unde : x poate fi litera L sau R 


Total instrucţiuni i ae) să 

E-p——a Eat 

RLA RRA 

Acţiunea :“RLA RA 
Conţinutul acumulatorului A este rotit Conținutul acumulatorului A este rotit 
cu o poziție la stinga. cu o poziție la dreapta. 
Bitul 7 se mută în Cy. Cy se mută Bitul 0 se mută în Cy. Cy se mută 
în bit 0. în bit 7. 
Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacţi procesor 


Se execută cu suprapunere de cicluri mașină. Fizic necesită 5 tacţi. 


Structura instrucţiunii : 


byte 


Tipuri de adresare : implicit 
Memento de cod 2 / RA 
RLA RRA 
cod AIA 1FH 
Flaguri afectate a CY,atii Și "PN 
Le e]xlolx [eo [+] 
Ss Z H PN Cy 
Exemple de utilizare : vol. II, p. 202 


AR/ LOG-8, DETALIAT 335 


ARIT — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 1: Adunare simplă cu acumulatorul în HL 


Mnemonica generică : ADD HL,rr 


unde : rr poate fi BC, DE, HL sau SP 


Total instrucţiuni pna 0 RAPA 


Acţiunea i HL = HL T Tr 


Conţinutul registrului dublu rr este adunat la conținutul registrului 
dublu HL. Rezultatul se obține în registrul dublu HL. Conţinutul 
registrului dublu rr rămîne neschimbat. 


Necesar de memorie : 1 byte 

Necesar de timp ; 11 1(4,4,3) tacţi procesor 
Structura instrucţiunii : 

Tipuri de adresare : op1 / op2 


implicit / implicit 
Memento de cod - ADD HLurr 
O09H  19H  29H 39H 


HL,BC|HL, DEJHL,HL|HL,SP 


Flaguri afectate i AG ANA 


flagul H=1, dacă a sea - n P | &y flagul Cy=1, dacă a existat transport de la 


transport de la bit 11 bit 15 


flagul N=0 indică adunarea efectuată 


Exemple de utilizare : vol. Il, p. 170 


336 280 — ANALIZA INSTRUCȚIUNILOR 


ARIT — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 2: Adunare simplă cu acumulatorul în IX 


Mnemonica generică : ADD IX,rr 


unde : rr poate fi BC, DE, IX sau SP 
Total instrucțiuni A i=4 


Acțiunea : IX = iX+rr 
Conţinutul registrului dublu rr este adunat la conținutul registrului 
dublu IX. Rezultatul se obține în registrul dublu IX. Conţinutul 
registrului dublu rr rămîne neschimbat. 

Necesar de memorie : 2 byte 


Necesar de timp : 15 (4,4,4,3) tacți procesor 


Structura instrucţiunii : 
bytep 


byte; 


Tipuri de adresare ; op1 / op2 
implicit / implicit 


Memento de cod Ş ADD IXurr 
09H  19H 29H 39H 


Flaguri afectate 2 "apti 


SZiu Hi PN Gy flagul Cy=1, dacă a existat transport de 


flagul H=.1, dacă a existat |. tabit15 


transport de la bit 11 flagul N=0 indică adunarea efectuată 


Exemple de utilizare : vol. Il, p. 174 


29 — Totul despre microprocesorul Z 80 vul. 1 şi 2. 337 


AI 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 3: Adunare simplă cu acumulatorul în IY 


Mnemonica generică ; f 


unde : rr poate fi BC, DE, IY sau SP 
Total instrucțiuni 0 SAR re 


Acţiunea 


Conținutul registrului dublu rr este adunat la conţinutul registrului 
dublu IY. Rezultatul se obține în registrul dublu IY. Conţinutul regis- 
trului dublu rr rămîne neschimbat. 


Necesar de memorie :; 2 byte 


Necesar de timp ; 15 (4,4,4,3) tacţi procesor 


Structura instrucţiunii : Et emitea 
bytep byte; 


Tipuri de adresare opl | op2 
implicit / implicit 


Memento de cod 


IY,BC | IY,DE |IY,IY | IY.sP 
Flaguri afectate 3 Ap DN 

[XXL lo[:] 

Ş 2 HO FENBp 
flagul H=71, dacă a existat tansport RE A__flagul Cy=1, dacă a existat transport 
de la bit11 de la bit 15 


flagul N=0 indică adunarea efectuată 


Exemple de utilizare 


338 


ARIT — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 4: Adunare cu adunarea transportului (carry) 


Mnemonica generică  : ADC HL,rr 


unde : rr poate fi BC, DE, HL sau SP 


Total instrucțiuni ; 4x1=4 


Acţiunea erati. HL fr IP Cy 


Se efectuează două adunări ; conținutul registrului dublu rr se adună 
la conţinutul registrului dublu HL. La suma astfel obținută se adună 
conținutul indicatorului de transport (carry). Rezultatul se obține în 
registrul dublu HL. Conţinutul registrului dublu rr rămîne neschimbat. 


Necesar de memorie : 72 byte 


Necesar de timp ; 15 (4,4,4,3) taci procesor 


Structura instrucţiunii : II + 


Tipuri de adresare ! opt /op2 
implicit / implicit 


Memento de cod : -ADC HL, -- 
4AH SAH G6AH 7AH 


Flaguri afectate ; toate 


L: [: [X[: lXIVloL: 


Sâ. [Hi PN Ur 
flagul H=1, dacă a existat transport Aga PAS 
de la bit 11 


flagul N=0 indică adunarea 
efeztuată 


flagul P]V indică depășirea 


Exemple de utilizare : vol. |l, p. 202 


E.7. ARIT-16, DETALIAT 339 


ARIT — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 5: Scădere cu scăderea transportului (carry) 


Mnemonica generică .SBC HL,rr 


unde : rr poate fi BC, DE, HL sau SP 
Total instrucţiuni se. Apis 


„Acţiunea ; HL = HL — Fr = Cy 


Se efectuează două scăderi : conținutul registrului dublu rr se scade 
din conținutul registrului dublu HL. Din diferența astfel obținută se 
scade conținutul indicatorului de transport. Rezultatul se obține în 
registrul dublu HL. Conţinutul registrului dublu rr rămîne neschimbat. 


Necesar de memorie : 2 byte 

Necesar de timp ; 15 (4,4,4,3) tacţi procesor 
Structura instrucţiunii CR 
Tipuri de adresare ş opt /op2 


implicit / implicit 


Memento de cod Ş SBC HLurr > 
42H__52H _ 62H -72H 


Flaguri afectate : toate 


|: XXXVI: 
Sri ala 
flagul H=1, dacă a existat set — flagul N=1 indică scăderea efectuată 


transport de la bit 11 flagul P/V indică depășirea 


Exemple de utilizare : vol. ||, p. 202 


340 ZB0 — ANALIZA INSTRUCȚIUNILOR 


ARIŢ — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 6: Incrementarea registrilor dubli 


Mnemonica generică : INC șă (i 

unde : rr poate fi BC, DE, HL, IX, IY, sau SP 
Total instrucţiuni i Piu e = 
Acţiune A eră. MB L 


Conţinutul registrului dublu rr este incrementat cu 1. 


Necesar de memorie : 1 byte pentru BC, DE, HL sau SP 
2 byte pentru IX sau IY 


Necesar de timp : 6 (6) tacți procesor pentru BC, DE, HL sau SP 
10 (4,6) tacți procesor pentru IX sau IY 


Structura instrucţiunii 


pentru BC, DE, HL sau SP 
pentru IX 


Ea peer pe 
pentru IY 
Dyteg byte 
Tipuri de adresare : implicit 


Memento de cod : INC rr 
035 2) SH 2223Her33H 


Dac [DE Fu] se] 
Flaguri afectate : nici unul 


= jXl= ăi -1-]-] 


Ş2 FI ENG 


Exemple de utilizare : vol. II, p. 195 


E,7. ARIT-16, DETALIAT 341 


ARIT — 16 


Clasa 5: Instrucţiuni aritmetice pe 16 bit 


Grupa 7: Decrementarea regiştrilor dubli 


Mnemonica generică : DEC Tr 
unde : rr poate fi BC, DE, HL, IX, IY sau SP 


Total instrucțiuni 2 Ab: 1-26 


Acţiunea : er SERE, 


Conţinutul registrului dublu rr este decrementat cu 7. 


Necesar de memorie : 1 byte pentru BC, DE, HL sau SP 
2 byte pentru IX sau IY 


Necesar de timp : 6 (6) tacți procesor pentru BC, DE, HL sau SP 
10 (4,6) tacți procesor pentru IX sau |Y 


Structura instrucţiunii : 


ZET: ISN, pentru BC, DE, HL sau SP 
COD pentru IX 


PREIA e a pentru IY 
Vie yte; 
Tipuri de adresare : implicit 


Memento de cod : DEC rr | 
OBH _' 1BH__2BH __3BH 


Flaguri afectate Ă nici unul 


COLI 
H 


>â Hi PNOy 


îxemple de utilizare : vol. Îl, p. 178 


342 780 — ANALIZA INSTRUCȚIUNILOR 


Clasa 6: Instrucţiuni logice pe blocuri de date 


Grupa 1: Comparări simple 


Mnemonica generică _: mi Wor sau 
unde : x poate fi litera | sau D 


Total instrucțiuni (N dă ftp, 
Acţiunea 


Conţinutul acumulatorului A este comparat cu cel al celulei de me- 
morie adresată prin registrul dublu HL. Indicatorul de adresă HL 
este incrementat cu 1 iar numărătorul de octeți BC este decrementat 
cu 1. Conţinutul acumulatorului A nu se schimbă. Rezultatul compa- 
rației se regăsește în registrul de flag F. 


'” 
| 


idem cu CPI, dar indicatorul de adresă HL este decrementat cu 1. 


Necesar de memorie : 2 byte 

Necesar de timp ; 16 (4,4,3,5) tacţi procesor 
Structura instrucţiunii : CR 
Tipuri de adresare op! / op2 


implicit / indirect 


Memento de cod 


ADH AH a2 A3H_ AH ASH _A6H A7H A ASN_AAH _ABH ACH ADH AEH AFH 
4 . 


XI 4 90aaa 
se a ca 
atata 00a0ai 


INI UT 00" IND GUTD 


Flaguri afectate ; toate cu excepţia lui carry 


CZ EZPA RARI IRI 


SOAP NC 
Z=1 dacă A=0 9 (___ P=0 dacă după efectuare BC=0 
Z=0 dacă Azt0 P=1 dacă după efectuare BCA0 


Exemple de utilizare : vol. II, p. 147 


LOG-IDR, DETALIA 1 343 


LOG — IDR 


Clasa 6: Instrucţiuni logice pe blocuri de date 


Grupa 2: Comparări multiple 


Mnemonica generică : CP x R (CPDR sau CPIR) 


unde : x poate fi litera | sau D 
Total instrucțiuni ști 
Acţiunea 


| + CPIR — compare, increment, repeat 
— CPDR — compare, decrement, repeat 


Conţinutul acumulatorului A este comparat cu cel al celulei de 
memorie specificată prin registrul dublu HL. Indicatorul de adresă 
HL este incrementat (CPIR) sau decrementat (CPDR) cu 1. Numără- 
torul de octeți BC este decrementat cu 1. Dacă rezultatul comparării 
arată egalitate instrucțiunea se termină, dacă nu, ea va fi reluată 
pînă cînd BC=0. Conţinutul acumulatorului A rămîne nemodificat. 


Necesar de memorie : 2 byte 


Necesar de timp : 21 (4,4,3,5,5) tacți procesor dacă Az(Hi.) şi BCzO 
16 (4,4,3,5) tacți procesor dacă A=(HL) sau BC=0 


Structura instrucţiunii : 
byteo DyAEI 


344 Z80 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare : opi / op2 
implicit / indirect 


d > (Po X] 
oa Pesosăbossăi 
LDIR INIROTIR LDDR INDR OTD 
Flaguri afectate 1 toate cu excepția lui carry 
MIRI EIRIEIRIEIEI 


Z=1, dacă A=(HL) A? A P=0, dacă după efectuare BC=0 
Z=0, dacă Az(HL) P=1, dacă după efectuare BC3+0 


Exemple de utilizare : 


Clasa 7: Instrucţiuni orientate pe bit 
Grupa 1: Testarea biţilor din regiştri 


Mnemonica generică : BIT Xp 


unde : x este numărul bitului [0,7] 
r poate fi B, C, D,E.H, Lsau A 
Total instrucţiuni nai f iei dszu 6 


Acțiunea 


Valoarea complementată a bitului x din registrul r este copiată în 
flagul Z. Conţinutul registrului r rămîne neschimbat. 


Necesar de memorie : 2 byte 
Necesar de timp ; 8 (4,4) tacţi procesor 
BI ERE, desi 
Structura instrucţiunii : EI di zizia aaa) 
i RR II, OO ZE ARIE 


unde : x2x1x0 este codul pe 3 bit al bitului testat 
r2rirO este codul pe 3 bit al registrului testat 
000—B  100—H 
001—C  101—L 


010—D 110 
011—E  111—A 
Tipuri de adresare ; opt | op2 


implicit / implicit 


Memento de cod « BI x, 


BIT Or 40He 


BIT 2,r SOHe 2, LRU2 Al3.a.c]3.0 Tera 2 S0He BIT ap 
BIT ar 60% hemos aia 5, A Bonearn sp 
m ay mbeelechobeb. rh- aohe or fn a ma 


Codul dorit se obține însumînd numerele aferente rîndului și colgarei 
în care se află instrucțiunea căutată. 


XR ABIT SE 50H + BH = 5BH 
Flaguri afectate PA alui 
BEE BEI 
PN 


Exemple de utilizare : E. 1, p. 156 


346 2.80 y INSTRUCŢII 


BITSR 


Clasa 7: Instrucţiuni orientate pe bit 


Grupa 2: Inscrierea (set) biţilor din regiștri 


Mnemonica generică : SEŢ X,r 


unde : x este numărul bitului [0,7] 
r poate fi B,C,D,E,H,L, sau A 


Total instrucţiuni BX Taci 
Acţiunea : Bit Xp = 1 
În bitul cu numărul x din registrul r se înscrie valoarea 1. 
Necesar de memorie : 2 byte 
Necesar de timp B 5 aa 4) tacţi i pa 
Structura instrucţiunii : 


unde : x2x1x0 este codul pe 3 bit al bitului setat 
r2rîrO este codul pe 3 bit al regiștrilor interni 


000 — B 100—H 

001 —C 101 —L 

010—D 110 

011 —E 111—A 
Tipuri de adresare : op /op2 

implicit / implicit 
Memento de a: | 

07100 SEL par 1 MR ei vie na 
XXI ”, 
7 cor peepopelere A of rover 
DOW+SET 3 


SET 2p DOM [2.82 ea ea sh cs ofarehe ih Era 


SET ap EOH+ Îa,B lu, Cl, Dle, Ea Hi e he | LES Al 5,als,cls.ols, eI5,H]s, L PX a] BM SET Sr 


EEE A DOaazaIE: Să user 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 
Ex SEI FOH + 0 = FOH 


Faguri aeccate : nici unul 
[+ + x [x] lee], 
SZ HN PNG 
Exemple de utilizare : vol. Il, p. 200 


SET 67 FOH+ 


E.9. BITSR, DETALIAT 347 


BITSR 


Clasa 7: Instrucţiuni orientate pe bit 
Grupa 3: Ștergerea (reset) biţilor din regiștri 


Mnemonica generică : RES X,Yr 


unde : x este numărul bitului [0,7] 
r poate fi B, C, D, E, H, Lsau A 


Total instrucțiuni Ea pese bi 
Acţiunea : bit x, = 
În bitul cu numărul x din registrul r se înscrie valoarea O. 
Necesar de memorie : 2 byte 
Necesar de timp : 8 (4,4) tacţi pișeesite 


Structura instrucţiunii îm2 ERA 
y 


byte 1 


unde : x2x1x0 este codul pe 3 bit al bitului resetat 
r2rirO este codul pe 3 bit al regiștrilor interni. 


000— B 100—H 
001 —C 101 —L 
010—D 110 
011—E 111—A 
Tipuri de adresare 3 op /op2 
implicit / implicit 
Memento de cod RES X,r 
i AI 03) i Oa GE AB Si A BC. DEE 
XX) 
eso aot pac hohefoo!  PRDof-afeP.ofepuep RER. crenes v 
pes pn ele cheola ia eri aaa af sola hu -eBQaa] a aes 
RES 4 ao [ek Croce he Lf deal of ep, JA] aoneREs 3 
XA LB i 
e vaze pecetea eo eur] coace 
Codul dorit se obține insumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 
Ex: RES 7,A BOH + FH = BFH 
Flaguri afectate : nici unui 
Rei ID 
AH PNE 
Exemple de utilizare : EA II, p. 156 


348 Z80 — ANALIZA INSTRUCȚIUNILOR 


BITSR 


Clasa 7: Instrucţiuni orientate pe bit 
Grupa 4: Testarea biţilor din locaţii de memorie 


Mnemonica generică  : BIȚ x,(mem) 


unde : x este numărul bitului [0,7] 
mem poate fi HL, IX .IND sau IY+IND 


Total instrucțiuni ue di 24 
Acţiunea : Z bit X (mem) 


Valoarea complementată a bitului x din celula de memorie adresată 
prin mem este copiată în flagul Z. Conţinutul celulei de memorie 
rămîne neschimbat. 


Necesar de memorie : 2 byte pentru HL 
4 byte pentru IX-+IND sau IY+IND 
Necesar de timp ; 12 (4,4,4) tacţi procesor pentru HL 
20 (4,4,3,5,4) tacți procesor pentru IX+IND sau 
IY+IND 


Structura instrucţiunii 


pis a pa pentru HL 
CB an 2220 


est > e zu 
Beer; ui pentru |X+IND 
PIE AEO em rea» reia Co Czzra— 
: dmmabii 
byte byte byte 


unde : x2x1x0 este codul pe 3 bit al bitului testat 
Tipuri de adresare : opl / op2 
implicit / indirect pentru HL 
implicit / indexat pentru IX-+IND sau IY+-IND 


Memento de cod BIT x (mem) 
46_H__4E _H--56.H SE H + 66.-H GE 276. 


Flaguri afectate 3 METEO 
[1x11 |x= lo e] 
SE H PN Cy 
Exemple de utilizare 


E.9. BiTSR, DETALIAT 409 


BITSR 


Clasa 7: Instrucţiuni orientate pe bit 
Grupa 5 : Înscrierea (set) biţilor din locaţii de memorie 


Mnemonica generică _: SET x,(mem) 


unde : x este numărul bitului [0,7] 
mem poate fi HL, IX+IND sau IY+IND 
Total instrucțiuni Bi Sie 2ă 


Acţiunea bit X(mem) 1 


În bitul cu numărul x in celula de memorie adresată prin mem, 
se înscrie valoarea 1. 


Necesar de memorie : 2 byte pentru HL 
4 byte pentru IX+IND sau IY+IND 
Necesar de timp ; 15 (4,4,4,3) tacţi procesor pentru HL 
23 (4,4,3,5,4,3) tacți procesor pentru IX-+IND sau 
IY+IND 


Structura instrucţiunii 


SET e 
[n Ţa Pefaol + [+ [o] pentru HL 


byteo 
pentru IX+IND 
pentry IY-+IND 


byte1 byte 2 byte3 


unde ; x2x1x0 este codul pe 3 bit al bitului setat 


Tipuri de adresare : opt /op2 

implicit / indirect  — pentru HL 

implicit / indexat  — pentru IX-+-IND sau IY +IND 
Memento de cod - SET x,(mem) 


C6-H-6E N OD6H IDE ID EG IN EEE II SFO Hi PE HI 


e Bre ua pei [ip Po eo 


Flaguri afectate : nici unul 
= [e |xje[xle ele! 
SZ H  PNCy 
Exemple de utilizare : vol. Il, p. 189 
350 


Z80 — ANALIZA INSTRUCȚIUNILOR 


Clasa 7: Instrucţiuni orientate pe bit 


Grupa 6: Ștergerea (reset) biţilor din locaţii de memorie 


> pe £* 4 

d U II) 

k bn x (mmmammaj 
N ELă „a De .î- Ş 


Mnemonica generică INCI 


unde ; x este numărul bitului [0,7] 
mem poate fi HL, IX+IND sau IY+IND 


Total instrucţiuni 9 AB Sec e ZA 
Acţiunea Iv | e 9 () 


În bitul cu numărul x din celula de memorie adresată prin mem, 
se înscrie valoarea 0. 


Necesar de memorie : 2 byte pentru HL 
4 byte pentru IX+IND sau IY -IND 
Necesar de timp ; 15 (4,4,4,3) tacţi procesor pentru HL 
23 (4,4,3,5,4,3) tacţi procesor pentru IX-+IND sau 
IY+IND 


Structura instrucţiunii 


RES, up 0 
[+ [o Pzfapo[* [+ [o] pentru HL 
îyte Dyle 1 
Catia] pentru IX +IND 
pentru IY + IND 
byte 0 byte byte 2 byte3 


unde : x2x1x0 este codul pe 3 bit al bitului resetat 


Tipuri de adresare Ă op / op2 
implicit / indirect  — pentru HL 
implicit / indexat  — pentru IX+IND sau IY+IND 


Memento de cod 21 E 


86 _H_8E_H 96 _H 9E _H _ A6 _H AEH B6H BEH 


cumani tmeraj2/neni[3jnem tiran) spe] /meri |raneni 


Flaguri afectate ; nici unul 
ee [x exe ie e] 
N PN 
Exemple de utilizare : vol. Il, p. 190 


351 


- BITSR 


Clasa 7: Instrucţiuni orientate pe bit 


Grupa 7: Manipularea indicatorului de transport (carry) 


Mnemonica generică _: x CF (SCF sau CCF) 


unde : x poate fi litera S sau C 
Total instrucțiuni 4 lasi] a 
Acţiunea ; SCF Cy = 1 înscrie indicatorul de transport 


CCF Cy=Cy complementează indicatorul de tran- 


sport 

Necesar de memorie : 1 byte 
Necesar de timp ; 4 (4) tacţi procesor 
Structura instrucţiunii 
Tipuri de adresare : implicit 
Memento de cod ID e CF 

SCF 37H 

CCF 3FH 


Flaguri afectate 


= Je |x lo [xle lol"! = lex lex lelolt! 
ZH 


S PN Cy Sz OH PNG 


Exemple de utilizare : vol. Il, p. 168 


352 Z80 — ANALIZA INSTRUCȚIUNILOR 


JUMP 


Clasa 8: Instrucţiuni de salt 


Grupa 1: Salt necondiționat absolut (direct) 


Mnemonica : JP nn 
unde : nn este o adresă [0,65535] 

Total instrucțiuni Sa 

Acțiunea $ PE 


În contorul program PC, se înscrie adresa nn. Programul se va executa 
în continuare de la adresa nn. 


Necesar de memorie : 3 byte 
Necesar de timp ; 10 (4,3,3) tacți procesor 
Structura instrucţiunii : [a EC Doza hat 
byte 0 byte 2 
Tipuri de adresare : direct 
Memento de cod : JP. nn 
cod = ES 
Flaguri afectate ; nici unul 
DAGBBARA 
FR PNCy 


Exemple de utilizare 


23 — Totul despre microprocesorul Z 80 vol. 1 şi 2 353 


Clasa 8: Instrucţiuni de salt 


Grupa 2: Salt necondiţionat absolut (indirect) 


E Da 


Mnemonica generică : „. 


unde: rr poate fi HL, IX sau IY 


Total instrucțiuni i de 13 


Acţiunea 


În contorul program PC, se copiază conținutul registrului dublu rr. 
Programul se va executa în continuare de la adresa specificată prin rr. 
Conţinutul registrului dublu rr nu se modifică. 


Necesar de memorie : 1 byte pentru HL 
2 byte pentru IX sau IY 


Necesar de timp ; 4 (4) tacți procesor pentru HL 
8 (4.4) tacți procesor pentru IX sau IY 


Structura instrucţiunii 


pentru HL, 


o te 
gri II. pentru i 
CE Ca pentru IY 
byte 1 


byte 


Tipuri de adresare ; indirect 


Memento de cod : JP (rr 


cod :""E9H 
Flaguri afectate : nici unul 
CIEZEVEIES EI ta ca 
PN Cy 
Exemple de utilizare : vol. II, p. 152 


Clasa 8: Instrucţiuni de salt 
Grupa 3: Salt condiţionat absolut (direct) 
inte 


ID «nn 
Mnemonica generică : «i pl 


unde : c este condiţia și poate fi NZ, Z, NC,C, PO, PE, Psau M 


Total instrucţiuni "8-31 28 
Acţiunea 


Se testează cîte un bit al registrului F. Dacă condiția căutată este adevă- 
rată se efectuează saltul (PC=—nn). În caz contrar programul continuă 
cu instrucțiunea următoare. 

Semnificația condiţiilor : 


NZ — non zero salt dacă Z=—0 


Z — zero salt dacă Z=1 
NC — non carry salt dacă Cy=0 
C — carry salt dacă Cy=1 


PO — parity odd 


salt dacă P/V=0 
PE — parity even 


salt dacă P/V=1 


N 0 ai 


P — plus salt dacă S=0 
M — minus salt dacă S=1 
Necesar de memorie : 3 byte 
Necesar de timp ; 10 (4,3,3) tacți procesor 
Structura instrucţiunii : 
y byte 0 byte 1 byte 2 
Tipuri de adresare i “direct 
Memento de cod ::JP c,nn 


C2u CAu  D2u DâAu  E2u EAu F2u FAu 


Pe Loz | zi mel eul poslee | e lutul 


Flaguri afectate : nici unul 


[= ]e Ixelxle ele] 
Zi 


S H PN 
Exemple de utilizare : vol. ||, p. 147 


E.10. JUMP, DETALIAT 


JUMP 


Clasa 8: Instrucţiuni de salt 


Grupa 4: Salt necondiţionat relativ 


Mnemonica generică : JR d 


unde : d este deplasamentul [—128, 4+127) exprimat în complemen- 
tul față de doi 


Total instrucţiuni Iu: 


Acţiune : PC=PC+d 


Deplasamentul d (număr cu semn) este adunat la valoarea curentă a 
contorului program PC. Se calculează astfel noua adresă, de la care 
se va continua execuția programului. 


Necesar de memorie : 2 byte 


Observaţie : În momentul în care se efectuează calculul adresei de 
salt, contorul program PC conține deja adresa instruc- 
ţiunii următoare, adresa care este cu +2 mai mare decît 
adresa instrucţiunii de salt însăși. De aceea plaja de 
adrese ce poate fi acoperită prin JR este de [—126, 
+129 ] față de adresa de început a instrucţiunii de salt. 


Necesar de timp ; 12 (4,3,5) tacţi procesor 


Structura instrucţiunii : 
yte O 


byte? 
Tipuri de adresare : imediat (relativ) 
Memento de cod JR d 
cod : 18H 

Flaguri afectate ; nici unul 

ee |x [e [xle Lele] 

sz H PNCy 
Exemple de utilizare : vol. Ii, p. 155 
356 


280 — ANALIZA INSTRUCȚIUNILOR 


JUMP 


Clasa 8: Instrucţiuni de salt 
Grupa 5: Salt condiționat relativ 


-Mnemonica generică _: JR c,d 


unde : c este condiția și poate fi NZ, Z, NC sau C 
d este deplasamentul [—128, +127] exprimat în complementul 


față de doi 
Total instrucţiuni 4 =4 
Acțiunea A 
Se testează cîte un bit al registrului F. Dacă condiția căutată este 
adevărată, se efectuează saltul (PC=—PC+d). În caz contrar se execută 
instrucțiunea următoare. Semnificația condiţiilor este : 
NZ — non zero —> salt dacă Z=0 
Z — zero —> salt dacă Z=1 
NC — non carry —> salt dacă Cy=0 
C — carry —> salt dacă Cy=1 
Necesar de memorie : 2 byte 
Observaţie : În momentul în care se efectuează calculul adresei de salt, 
contorul program PC conține deja adresa instrucţiunii urmă- 
toare, adresa care este cu -+2 mai mare decît adresa instruc- 
ţiunii de salt însăși. 
De aceea plaja de adrese ce poate fi acoperită prin JR c,d 
este de [—126, +129] față de adresa de început a instrucțiu- 
nii de salt. 
Necesar de timp : 12 (4,3,5,) tacţi procesor dacă condiția este adevărată 
7 (4,3) tacți procesor dacă condiția este falsă (fără salt). 
Structura instrucţiunii : Er 
byteo e1 
Tipuri de adresare : imediat (relativ) 
Memento de cod ţ JR c,d 
204 284 304 384 
e Țz [e [e] 
Flaguri afectate : nici unul 


PN Cy 
Exemple de utilizare  : i II, EI 145, p. 153 


E.10. JUMP, DETALIAT 357 


JUMP 


Clasa 8: Instrucţiuni de salt 


Grupa 6: Salt condiţionat relativ cu decrementare 


Mnemonica - DJNZ d (Decrement Jump Not Zero) 


unde : d este deplasamentul [—128, +127] exprimat în complementul 
față de doi 


Total instrucţiuni 3 2 


Acţiunea 


Conţinutul registrului B este decrementat cu 1. Dacă astfel s-a ajuns 
la valoarea B=0, atunci se execută instrucțiunea următoare din 
program. În caz contrar se efectuează un salt relativ (PC=PC+d). 


Necesar de memorie : 2 byte 


Observaţie : În momentul în care se efectuează calculul adresei de salt, conto= 
rul program PC conţine deja adresa instrucţiunii următoare, 
adresă care este cu +2 mai mare decît adresa instrucţiunii de salt 
însăși. De aceea plaja de adrese ce poate fi acoperită prin DJNZ d, 
este de [—126, +129)] față de adresa de început a instrucţiunii DJNZ. 


Necesar de timp ; 13 (5,3,5) tacți procesor dacă se efectuează saltul 
B7+0 
8 (5,3)  tacți procesor dacă nu se efectuează saltul 
(B=0) 
Structura instrucţiunii CR 
Tipuri de adresare : opi | adresa de salt 
implicit / imediat (relativ) 
Memento de cod : DINZ d 
cod :10H 
Flaguri afectate : nici unul 
e e [x le [xle Lele] 
sz H PNCy 


Exemple de utilizare : vol.|l, p. 174 p. 176 


35B 780 — ANALIZA INSTRUCȚIUNILOR 


CALL/RET 


Clasa 9: Instrucţiuni de apel și revenire din subrutine 


Grupa 1: Apel necondiționat 


Mnemonica j CALL nn 


unde : nn este o adresă [0,65535] 


Total instrucţiuni a STĂ 


Acţiunea : SP SP - 4 
(SP) «— PChigh 
SP= SP-—1 
(SP) = PCiow 
PC = nn 


Conţinutul contorului program PC este salvat în virful stivei, după 
care PC este încărcat cu noua adresă nn. Conținutul indicatorului de 
stivă SP este decrementat cu 2. 


Necesar de memorie : 3 byte 

Necesar de timp ; 9) (4,3,4,3,3) tacţi procesor 

Structura instrucţiuni : : 
byte 0 byte! byte 2 

Tipuri de adresare : adresa de salt / adresa de revenire 


direct / indirect 


Memento de cod : CALL nn 
cod : GDH 
Flaguri afectate ; nici unul 


eje |ehe xl ebije) 


sz H PN Cy 
Exemple de utilizare : vol. Il, p. 155, p. 173 


E.11. CALL/RET, DETALIAT 359 


CALL/RET 


Clasa 9: Instrucţiuni de apel și revenire din subrutine 


Grupa 2: Revenire necondiționată 


Mnemonica » : REŢ 


Total instrucţiuni E 


Acţiunea - PCiow —— (SP) 
SP= SP +1 
PChigh — (SP) 
SP= SP-+1 


Adresa de revenire din subrutină în programul apelant este presupusă 
a se afla în virful stivei. Ea se încarcă în contorul program PC, după 
care se efectuează saltul, Conţinutul indicatorului de stivă SP este 


incrementat cu 2. 


Necesar de memorie : 1 byte 
Necesar de timp ; 10 (4,3,3) tacți procesor 
Structura instrucţiunii : cea 
Tipuri de adresare. : adresa de revenire 
indirect 

Memento de cod : REŢ 

cod 3 CH 
Flaguri afectate ; nici unul 

sz H FNQ 


Exemple de utilizare : vol. Il, p. 155, p. 176 


360 280 — ANALIZA INSTRUCȚIUNILOR 


Clasa 9: Instrucţiuni de apel și revenire din subrutine 


Grupa 3: Apel condiționat 


Mnemonica generică _: CALL c,nn 


unde ; c este condiția și poate fi: NZ, Z, NC, C, PO, PE, Psau M 
nn este o adresă [0,65535] 


Total instrucțiuni : 8x1=3 
Acţiunea : dacă c este adevărată se execută saltul la subrutină 


SP.= SP —1 
(SP)— PChigh 
SP=SP-—1 
(SP)— PCiow 
PC=m 


Se salvează adresa de revenire în vîrful stivei, se încarcă PC cu nn. 
Indicatorul de stivă SP este decrementat cu 2. Dacă c este falsă se 
execută instrucțiunea următoare din program. 
Semnificația condiţiilor : 


NZ 


Necesar de memorie : 3 byte 


Necesar de timp 


non zero 
zero 

non carry 
carry 

parity odd 
parity even 
plus 

minus 


e, 


00 E E a: 


salt dacă 


CALL/RET 


Z=0 


salt dacă Z=1 


salt dacă 
salt dacă 
salt dacă 
salt dacă 
salt dacă 
salt dacă 


17 (4,3,4,3,3) tacți procesor dacă se 


10 (4,3,3) tacți procesor dacă nu se 


E.11. CALL/RET, DETALIAT 


Cy=0 
Cy==1 
P/V=0 
P/V=1 
s=0 
s= 


efectuează saltul 
efectuează saltu | 


36; 


Structura instrucţiunii : Lg PE 


byte 2 


Tipuri de adresare : “adresa de salt / adresa de revenire 
direct | indirect 


Memento de cod : CALL c,nn 


CH CCH Du DCh En Ec Fu FCu 


Tg RR IT ERIE PA NCI ED ECD Ea a 


Flaguri afectate : nici unul 
DDEIEIEEIEI 
S2 H RN Ci 


exemple de utilizare _: vol. Il, p. 155 


CALL/RET 


Clasa 9: Instrucţiuni de apel și revenire din subrutine 


Grupa 4: Revenire condiţionată 


Mnemonica generică : RET Let 


unde : c este condiția și poate fi NZ, Z, NC, C, PO, PE, Psau M 


Total instrucțiuni 0 pl == 8 
Acţiunea : dacă c este adevărată se execută revenirea în prosra- 
mul apelant 


PCiow — (SP) 
SP= SP+1 
PChigh ——(3P) 
SP= SP +7 
Adresa de revenire este presupusă a fi în vîrful stivei. Ea se încarcă 


în contorul program. Conţinutul indicatorului de stivă este incremen- 
tat cu 2. 


Dacă condiția c este falsă se execută următoarea instrucțiune din 
program. 


Semnificația condiţiilor : 


NZ — non zero — salt dacă Z=0 
Z — zero — salt dacă Z=1 
NC — non carry —» salt dacă Cy=0 
C — carry — salt dacă Cy=1 
PO — parity odd — salt dacă P/V=0 
PE — parity even  —> salt dacă P/V=1 
P — plus — salt dacă S=0 
M — minus — salt dacă S5=1 
Necesar de memorie : 1 byte 
Necesar de timp : 11 (5,3,3) tacți procesor dacă se efectuează revenirea 


5 (5) tacți procesor dacă nu se efectuează revenirea 


EUL. CALL/RET, DETALIAT 363 


Structura instrucţiunii : 


byte 


Tipuri de adresare ; adresa de revenire 
indirect 


Memento de cod : REŢ C 


COM  C8u DOm D8u  EOu  E8u FO 


De Ţe Dhe [e [ee [n 
Flaguri afectate ; nici unul 


Exemple de utilizare : vol. Il, p. 182 


CALLĂRET 


Clasa 9: Instrucţiuni de apel și revenire din subrutine 


Grupa 5: Apel scurt, necondiţionat, la adrese fixe 


Mnemonica generică  : RST 4) 


unde : n este o adresă din pagina 0 și poate fi 0, 8, 10H, 18H, 20H, 
28H, 30H sau 38H 


Total instrucțiuni sa PE: 


Acţiunea ; SP >: SP 2 1 
(SP)—PChigh 
SP SP —1 
(SP) —PClow 
PC- 


Se salvează adresa de revenire (PC) în virful stivei. PC se încarcă cu 
n și se execută saltul. Conţinutul indicatorului de stivă SP este decre- 


mentat cu 2. 


Necesar de memorie : 1 byte 
Necesar de timp ; 11 (5,3,3) tacți procesor 4 
Structura instrucţiunii : 
Tipuri de adresare : adresa de salt / adresa de revenire 
implicit / indirect 
Memento de cod : RST n 
C7uy _CFu _D7w DFu _E7u EFHh _F7H __FFH 

Do e [oa [er jam [eee [ee [ee ] 

Flaguri afectate : nici unul 


e [e [x [e [xle je Le] 


sz H PN Cy 


Exemple de utilizare 


ELI. CALL/RETŢ, DETALIAT 365 


ROT/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 


Grupa 1: Rotiri „,cu”' carry a regiştrilor 


Mnemonica generică : R fe: și (RLC sau RRC) 


unde : x poate fi litera L sau R 
r poate fi B, C, D,E, H,Lsau A 


Total instrucțiuni > 19309714 


Acţiunea 


RLC RRC 


Lă ls 
ENE Era 


Conţinutul registrului r este deplasat Conţinutul registrului r este deplasat 
cu o poziţie la stînga. cu o poziție la dreapta. 
Bitul 7 se transfera în flagul carry Bitul O se transferă în flagul carry și 
și în bitul O. în bitul 7. 
Necesar de memorie : 2 byte 
Necesar de timp : 8 (4,4) tacţi procesor 
| 7 PE PI A 
Structura instrucţiunii : [ele pzeaolrzlr[ro] 


byle0 byte! 


unde : 020100 reprezintă codul pe 3 bit al operației RGT/SHIFT 


000—RLC 100—SLA 

001 —RRC 101 —SRA 

010—RL 110 

011 —RR 111—SRL 

r2rîr0 reprezintă codul pe 3 bit al regiștrilor 
interni 

000—B 100—H 

001 —C 101 —L 

010—D 110 

011—E 111—A 


356 Z80 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare : implicit 


(CC i (RLC sau RRC) 
Memento de cod R e RI | (RLC sau RRC) 


isz 


23 


SII 
poza 
2 


= 
za 
aa 


EBEEI 
7 


SĂ 
99 


ai 
e A 


ze: 

3 

23 
29 


2505 
a 


a 
[Sosee> 


V/ 


a 


3 
e 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 


Exemplu: RLC D 00H 4+-2==02H 
“laguri afectate ; toate 
HBEICIEI CICI 
P Cy 


flagul PV indică paritatea 


Exemple de utilizare : vol. II, p. 198 


ROT/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 


Grupa 2: Rotiri „print carry a regiştrilor 


Mnemonica generică Rx r (RL sau RR) 


unde : x poate fi litera L sau R 
r poate fi B, C, D, E, H, Lsau A 


Total instrucțiuni Di D210 


Acţiunea 


E E -ehH 
Conţinutul registrului r este deplasat Conţinutul registrului r este deplasat 
cu o poziţie la stînga. Bitul 7 se trans- cu o poziţie la dreapta. Bitul 0 se tran- 
feră în carry; carry se transferă în sferă în carry ; carry se transferă în 
bitul 0. bitul 7. 
Necesar de memorie : 2 byte 
Necesar de timp OIL, (4,4) tacți procesor 


Structura instrucţiunii 


R/SH op ă 
unde : 020100 reprezintă codul pe 3 bit al operației ROT/SHIFT 

000—RLC 100—SLA 

001 —RRC 101 —SRA 

010—RL 110 

011—RR 111—SRL 

r2rîr0 reprezintă codul pe 3 bit al regiștrilor interni 

000—B 100—H 

001 —C 101 —L 

010—D 110 

011—E 111—A 


368 Z80 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare : implicit 


Memento de cod R [ (RL sau RR) 


BI DVI 708 Therm 
D074 pe 


Codul dorit se obține însumînd numerele aferente rîndului și coloa- 
nei în care se află instrucțiunea căutată. 


RLC r 00H+ 


RL r 10H+ 


SULA r 20H+ 


A 


Exemplu: RR L 10H+DH=1DH 
Flaguri afectate ; toate 
LEFGEB CERTA Ea 
PN Cy 


flagul P/V indică paritatea = 


Exemple de utilizare : volll, p. 199 


24 — Totul despre microprocesorul Z 80 vol. 1 si 2 


Clasa 10: Instucțiuni de rotire/deplasare 


Grupa 3: Deplasări (shift) aritmetice ale regiștrilor 


P> By 
Mnemonica generică  : S Ă PP 


unde : x poate fi litera L sau' 


r poate fi-B,C, D, E, 
Total instrucțiuni 2xX7=14 
Acțiunea 
SLA 
r 
E 


Conţinutul registrului r este deplasat 
cu o poziție la stînga. Bitul 7 se tran- 
sferă în carry. În bitul O se inserează 
valoarea 0. 


Necesar de memorie 2 byte 


Necesar de timp 


Structura Instrucțiunii La 
yte 


8 (4,4) tacţi procesor 


(SLA sau SRA) 
R 
H, Lsau A 
SDA 
. 


Conţinutul registrului r este deplasat 
cu o pozție la dreapta. Bitul 0 se tran- 
sferă în carry. Bitul 7 rămîne neschim- 
bat. 


R/SH 


op r 
IEI CALCI 
byte ? 


unde : 020100 reprezintă codul pe 3 bit al operaţiei ROT/SHIFT 


000—RLC 100—SLA 
001 —RRC 101 —SRA 
010—RL 110 

011 —RR 111—SRL 


r2rirO reprezintă codul pe 3 bit al regiștrilor interni 


001 —C 101—L 
010—D 110 
011—E M1—A 


370 


Z80 — ANALIZA INSTRUCȚIUNILOR 


Tipuri de adresare” : ” implicit 


r (SLA sau SRA) 


"(totoraced 
DO 
te 
III | /Pommnrer 
NI 
otet, XI 
FA Da Joe RR 
dia 2 


AEaaaa poe 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 


Memento de cod i SICA 


III 
VA, 


e 
Se Dă 
SSI 

se 


sos 
a: 
o Seă 
SS 
sa: 


RLC r 0OH* 


fas 
2 

a sat 

e 


Se 


=: 
sia: a 
atata 


Sg 


A 


SI 
=> 


N 
> 
3 


Szazat 
ASRRRIS 
tai 


RL r 10He 


RE 


SLA , 20Hu 


Exemplu: SRA A 20H + FH =2FH 
Flaguri afectate ; “toate 
IHEIEIEIGEILA 
IPN 


flagul P/V indică paritatea 


Exemple de utilizare : 


ROT,/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 
Grupa 4: Deplasări (shift) logice ale regiştrilor 


Mnemonica generică : SRL pi 
unde : r poate fi B, C, D,E, H, Lsau A 
Total instrucțiuni N ac 3 7 ay 
Acţi : L 
cţiunea | of E 


Conţinutul registrului r este deplasat cu o poziție la dreapta. Bitul: 
O se transferă în carry. 
În bitul 7 se inserează valoarea 0. 


Necesar de memorie :: 2 byte 
Necesar de timp : 8 (4,4) tacţi PCREgI 
Structura instrucţiunii : e: vez 
unde : 020100 reprezintă codul pe 3 bit al operației ROT/SHIFT 
000—RLC 100—SLA 
001 —RRC 101 —SRA 
010—RL 110 
011—RR 111—SRL 
r2rir0 reprezintă codul pe 3 bit al regiștrilor interni : 
000— B 100—H 
001 —C 101—L 
010—D 110 
011—E 111—A 
Tipuri de adresare :. implicit 


ia AP "99 


ZII 0 eee 
0 7iza | 


V "785 7] 
pă 
4/4 AX 
pă 


Codul dorit se obține însumînd numerele aferente rîndului și coloanei 
în care se află instrucțiunea căutată. 


mer 


RR r 10re// 


AP 
A /I/| 


Ar 20He/ 


Exemplu : SRL E 30H4+BH=3BH 
Flaguri afectate ; toate 
[i lxlolxie lo] 
H PN Cy 


flagul P/V indică paritatea 
Exemple de utilizare : vol. Il, p. 197 


372 | Z80 — ANALIZA INSTRUCȚIUNILOR 


Clasa 10: Instrucţiuni de rotire/deplasare 


ROT SHIFT 


Grupa 5: Rotiri „cu“ carry a locațiilor de memorie 


i 
Mnemonica generică 


R x C (mem) (RLC sau RRC) 


unde : x poate fi litera L sau R 


mem poate fi HL, IX+I 


Total instrucțiuni 2xX3=6 


Acţiunea 


Conținutul celulei de memorie adre- 
sată prin mem este deplasat cu o 
poziție la stînga. 

Bitul 7 se transferă în carry și în 
bitul 0. 


Necesar de memorie 
4 byte pentru | 


ND sau IY+IND 


RRC 


(mem ) 
= 


Conţinutul celulei de memorie adre= 
sate prin mem este deplasat cu o 
poziție la dreapta. 

Bitul O se transferă în carry și în 
bitul 7 


2 byte pentru HL 


X-+IND sau IT-+IND 


Necesar de timp 15 (4,4,4,3) tacți procesor pentru HL 

23 (4,4,3,5,4,3) tacți procesor pentru IX-IND sau 

IY+IND 
Structura instrucţiunii 
re Ela 
[o [o [22(2+]2a]* |n [o] pentru HL 
byte 0 byte 1 
pentru IX+IND 
[cos lidem) | pentru |Y+IND 
byte 0 byte 1 byte 2 byte 3 


ROT/SHIFT, DETALIAT 


373 


unde : 020100 este codul pe 3 bit al operației ROT/SHIFT 


000—RLC 100—SLA 

001 —RRC 101 —SRA 

010—RL 110 

011 —RR 111—SRL 
Tipuri de adresare :  indirest pentru HL 


indexat pentru IX+IND sau IY+IND 


Memento de cod : RC (mem) (RLC sau RRC) 
RLC (mem) RRC (mem) 
cod ; 06H 0EH 
Flaguri afectate ; toate 


LD! [i |xJolxIelol:| 
SRI H PN Cy 
flagul P/V indică paritatea 


Exemple de utilizare 


ROT/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 


Grupa 6; Rotiri „prin“ carry ale locaţiilor de memorie 


R.X 
3 PN 


Mnemonica generică 


(mem) (RL sau RR) 


unde : x poate fi litera L sau R 
mem poate fi HL, IX+IND sau IY+IND 


Total instrucțiuni 2% 3=6 


Acţiunea 


RL 


[mem ) 


er P=—— a 


Conţinutul celulei de memorie adre- 
sată prin mem este deplasat la stînga 
cu o poziție. Bitul 7 se transferă în 
carry. Carry se transferă în bitul O. 


Necesar de memorie 


RR 


(mem ) 


i ———— 


Conţinutul celulei de memorie adre- 
sată prin mem este deplasat la dreapta 
cu o poziție. Bitul O se transferă în 
carry. Carry se transferă în bitul 7. 


să byte pentru HL 


4 byte pentru IX+IND sau IY+IND 


Necesar de timp 15 (4,4,4,3) tacți procesor pentru HL 


23 (4,4,3,5,4,3) tacţi procesor pentru IX+IND sau 


IY+IND 
Structura instrucţiunii ! 
R/SH _op _ mem 
(5 [o Paul: Ti [7] pentru HL 
byte O byte 1 
pentru IX+IND 
MN E ZII Mma PEE i pentru !Y=IND 
>yte 0 byte 2 byte? byte 3 


unde : 020100 este codul pe 3 bit al operației ROT/SHIFT 


000—RLC 100—SLA 
001 —RRC 101 —SRA 
010—RL 110 

011 —RR 111—SRL 


E.12. ROT/SHIFT, DETALIAT 375 


Tipuri de adresare : indirect pentru HL 
indexat pentru IX+IND sau IY-+-IND 


Memento de cod : Rx (mem) (RL sau RR) 
RL (mem) RR (mem) 
cod : 16H 1EH 
Flaguri afectate ; toate 
L: Lt |xJolx[e[o[] 
32 PNE, 


flagul P/V indică paritatea 


Exemple de utilizare 


Clasa 10 + Instrucţiuni de rotire/deplasare 


ROT/SHIET 


Grupa 7: Deplasări (shift) aritmetice ale locaţiilor de memorie 


Mnemonica generică : S x A (mem) (SLA sau SRA) 


unde : x poate fi litera L sau R 
mem poate fi HL, IX+IND sau IY+IND 


Total instrucțiuni 23 =5 


Acțiunea 


SLA 


Conţinutul locației de memorie adre- 
sată prin :mem este deplasat la stinga 
cu o poziție. Bitul 7 se transferă în 
carry. În bit:0 se inserează valoarea 0. 


Necesar de memorie 


SRA 


(mem ) 
E cy| 


Conţinutul locației de memorie adre- 
sată prin mem este deplasat la dreapta 
cu o poziție. Bitul 0 se transferă în 
carry. Bitul 7 rămîne neschimbat. 


2 byte pentru HL 


4 byte pentru IX-+IND sau IT+IND 


Necesar de timp ; 15 (4,4,4,3) tacți procesor pentru HL 
23 (4,4,3,5,4,3) tacți procesor pentru IX+IND sau 
IY+IND 
Structura instrucţiunii 
R/SH op mem 
oo Poemele pentru HL 
DD sa) pentru IX+IND 
E Co cogisșa —) pentru IY-+-IND 


unde : 020100 este codul pe 3 bit al operației ROT/SHIFT 


000—RLC 100—SLA 
001 —RRC 101 —SRA 
010—RL 110 

011—RR 111—SRL 


E.12. ROT/SHIFT, DETALIAT 


Tipuri de adresare : indirect pentru HL 
indexat pentru IX+IND sau IY+IND 


Memento de cod : SxĂ (mem) (SLA sau SRA) 
SLA (mem) SRA (mem) 
cod ; 26H 2EH 
Flaguri afectate : toate 


[Y[xlolxIe olt] 
SA PO Cy 


flagul P/V indică paritatea 


Exemple de utilizare 


ROT/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 
Grupa 8: Deplasări (shift) logice ale locațiilor de memorie 


Mnemonica generică : SR L (mem) 
unde : mem poate fi HL, IX-+FIND sau IY+IND 
Total instrucţiuni IE 3 


Acţiunea y SRL 


mem) 


5 


Conţinutul celulei de memorie adresată prin mem este deplasat cu 
o poziție la dreapta. Bitul 0 se transferă în carry. În bitul 7 este 
inserată valoarea 0. 


0 A 


Necesar de memorie : 2 byte pentru HLI 
4 byte pentru IX-+-IND sau IY+IND 
Necesar de timp ; 15 (4,4,4,3) tacţi procesor pentru HL 
23 (4,4,3,5,4,3) tacți procesor pentru IX+IND sau 
IY+IND 
Structura instrucţiunii 
R/SH _op mem 
[oo IpzfiPa[: o] : pentru HL 
byte 0 byte 1 
a] pentru IX+IND 
[cod lidem! _] pentru Y+IND 
byte 0 byte byte 2 byte 3 
unde : 020100 este codul pe 3 bit al operației ROT/SHIFT 
000—RLC 100—SLA 
001 —RRC 101 —SRA 
010—RC 110 
011 —RR 111—SRL 
Tipuri de adresare ; “indirect pentru HL 
indexat pentru IX--IND sau IY+IND 
Memento de cod : SRL (mem) 
cod 3 JEH 
Flaguri afectate ; toate 
L. |! ]xlolxJeloL!! 
57" ERG 


flagul P/V indică paritatea 
Exemple de utilizare 


F.12. ROT/SHIFT, DETALIAT 379 


ROT/SHIFT 


Clasa 10: Instrucţiuni de rotire/deplasare 
Grupa 9: Rotirea digiților de 4 bit 


Mnemonica generică : R.D (RLD sau RRD) 


unde : x poate fi litera L sau R 
Total instrucţiuni Alia = 2 


Acţiunea 


RLD RRD 


RLD RRD 
AZI II CCA E es) [II AZI EAI = aaa 
Ta ez [ese s4 
Conţinutul celulei de memorie adre- Conţinutul celulei de memorie adre- 
sată prin conținutul registrului dublu sată prin conținutul registrului dublu 
HL, este rotit la stînga folosind digitul HL, este rotit la dreapta folosind 
inferior al registrului A. digitul inferior al registrului A. 
Biții 3—0 ai lui A trec în biții 3—0 Biții 3—O-ai lui A trec în biții 7—4 
ai lui (HL). ai lui (HL). 
Biții 3—O0 al lui (HL) trec în biții 7—4 Biții 7—4 ai lui (HL) trec în biții 3-—0 
ai lui (HL). ai lui (HL). 
Biții 7—4 ai lui (HL) trec în biții 3—0 Biții 3—0 ai lui (HL) trec în biții 3—0 
ai lui A. ai lui A. 
Necesar de memorie : 2 byte 
Necesar de timp : 18 (4,4,3,4,3) tacți procesor 
Structura instrucţiunii : 
byte 0 byte 1 
Tipuri de adresare A op1 / op2 


implicit / indirect 


Memento de cod . RxD (RLD sau RRD) 


RLD RRD 
cod ;: 6FH 67H 
Flaguri afectate ; toate cu excepția lui carry 
| !]x]o]xle]ol:] 
Su H P N Cy 
flagul P/V indică parita: A (edi, 


Exemple de utilizare : vol. Il, p. 186 


380 780 — ANALIZA INSTRUCȚIUNILOR 


INJOUT 


Clasa 11 : Instrucţiuni de intrare/ieșire 


Grupa 1: Intrare (Input) cu adresare directă 


Mnemonica generică : IN A,(n) 


unde : n este o adresă de port [0,255]. 


Total instrucțiuni se 


Acţiunea E N dota (n) 


Conţinutul portului de intrare adresat prin n este transferat în registrul 
A. Conținutul vechi al acumulatorului A se pierde. 


Necesar de memorie : 2 byte 


Necesar de timp ; 11 (4,3,4) tacţi procesor 


In ultimul ciclu mașină, M3 (4 tacți procesor), starea magistralei de 
adrese este următoarea : 
A0—A7 numărul n 


A8— A15 vechiul conținut al registrului A 


Structura instrucţiunii : TEI 
byte 1 


byte 0 


Tipuri de adresare : destinaţie / sursă 
implicit / direct 
Memento de cod : IN A,(n) 
cod ; DBH 
Flaguri afectate : nici unul 


[=Ţe x[e [x lee le] 


SZ H PN Cy 


Exemple de utilizare : vol. Il, p. 158 


E.13: IN/OUT, DETALIAT 381 


"INJOUT 


Clasa 11 : Instrucţiuni de intrare/ieșire 


Grupa 2: Intrare (Input) cu adresare indirectă 


Mnemonica generică : Li) r,(C) 


unde : r poate fi B, C, D,E,H,L,sau A 


Total instrucțiuni ; 717 


Acţiunea CAE la amp (C) 


Conţinutul portului de intrare adresat prin conţinutul registrului C 
este transferat în registrul r. Vechiul conținut al registrului rse pierde, 


Necesar de memorie : 2 byte 


Necesar de timp ; 12 (4,4,4) tacți procesor 
In ultimul ciclu mașină, M3 (4 tacți procesor), starea magistralei de 
adrese este următoarea : 
A0— A7 conţinutul registrului C 
A8— A15 conținutul registrului B 


Structura instrucţiunii : 
byte 0 byte ! 
Tipuri de adresare 4 destinaţie / sursă 


implicit / indirect 


Memento de cod ref IN r(C) 


40H_48H _50H 58H 60H 68H 70H 78 


spe) eeo[oacţeze|Hrele-re) 


Flaguri afectate ; toate cu excepția lui carry 
Se observă deosebirea față de input cu adresare directă, care nu pozi- 
ționează indicatorii de stare. 


A 
E li [x [lee 


Ş 2 PN Cy 


flagul P/V indică paritatea 
Exemple de utilizare : vol. II, p. 197 


382 780 — ANALIZA INSTRUCȚIUNILOR 


Clasa 11 : Instrucţiuni de intrare/ieșire 


Grupa 3: leşire (Output) cu adresare directă 


Mnemonica generică : OUȚ (n), A 


unde : n este o adresă de port [0,255]. 
Total instrucțiuni A 


Acţiunea : (n)— A 


Conţinutul acumulatorului este transferat în portul de ieșire cu adresa 
n. Conţinutul acumulatorului: nu este afectat, | 


Necesar de memorie : 2 byte 


Necesar de timp ; 11 (4,3,4) tacți procesor 
În ultimul ciclu mașină, M3 (4 tacți procesor), starea magistralei de 
adrese este următoarea ; 
A0— A7 conţine numărul n 
A8— A15 conținutul registrului A 


Structura Instrucțiunii : EA ridicată 
byte 0 byte 


Tipuri de adresare ; destinație / sursă 
direct / implicit 


Memento de cod : OUT (n), A 


cod 2 DD3H 


Flaguri afectate : nici unul 


= [x e lx]e [e [e] 
S Z PNG, 


Exemple de utilizare : vol. ||, p. 145 


E.19. IN/OUT, DETALIAT 383 


INJOUT 


Clasa 11 : Instrucţiuni de intrare/ieșire 


Grupa 4: leșire (output) cu adresare indirectă 


Mnemonica generică  : OUT (C),r 


unde: r poate fi B, C, D, E. H, L sau A 


Total instrucţiuni y PARĂ? 


Acţiunea (C) sal 


Conţinutul registrului r este transferat la portul de ieșire avînd adresa 
specificată prin conținutul registrului C. Conţinutul registrului r 
nu se modifică. 


Necesar de memorie : 2 byte 


Necesar de timp ; 12 (4,4,4) tacţi procesor 
In ultimul ciclu mașină, M3 (4 tacți procesor), starea magistralei de 
adrese este următoarea ; 
A0— A7 conținutul registrului C 
AB8— A15 conținutul registrului B 


Structura instrucţiunii : 
byte byte 1 
Tipuri de adresare : destinaţie / sursă 


indirect / implicit 


Memento de cod : OUT (C),r 


49H 51H 59H 61H S9H 71H a 
ec Force | 


Flaguri afectate ; nici unul 


(+ e [x|e |xlele[e) 
S Z PN Cy 


Exemple de utilizare 


384 Z80 — ANALIZA INSTRUCȚIUNILOR 


INJOUT 


Clasa 11 : Instrucţiuni de intrare/ieşire 
Grupa 5 : l/E blocuri de date — Intrare (input) simplă 


Mnemonica generică  : IN X (INI sau IND) 


unde : x poate fi litera | sau D 


Total instrucţiuni Ma 2 
Acţiunea INI (in &increment) 
(HL) <— (C) 
HL HL +1 
B B 1 


Conţinutul portului de intrare adresat prin conținutul registrului C, 
este transferat în memorie la adresa specificată de registrul dublu 
HL. Indicatorul de adresă HL este incrementat cu 1. Numărătorul 
de octeți B este decrementat cu 1. 


IND (in &decrement) 


(HL) « (€) 
HL=HL—1 
B =B —1 
Idem cu INI, dar indicatorul de adrese este decrementat cu 1. 
Necesar de memorie : 2 byte 
Necesar de timp ; 16 (4,5,4,3) tacţi procesor 
În ultimul ciclu mașină M3 (4 tacți) starea magistralei de ati dtie este 
următoarea : 


AO — A7 conținutul registrului C 
A8 — A15 conținutul registrului B decrementat 


Structura instrucţiunii : l 
Tipuri de adresare ; destinaţie / sursă 
indirect / indirect 
Memento de ea i IN X 
A HAZ HASH  AGH.A Aia 9 H, AAH,ABHIAC HIAD Hu AEH,AFH 
Zi AI no A 
LDI PI BUT! LDD CPD  QUTD 
Fiaguri afectate ; S, H, P — necunoscute - 
N — devine 1 
Cy — neafectat 


CIP RED EEE ENE 
4 Y 


Z=1 dacă după execuție B=0 
„2=0 dacă după execuţie Bz0 


Exemple de utilizare 


25 — Totul despre microprocesorul Z 80 vol. 1 și 2 385 
4 


IN/OUT 


Clasa 11 : Instrucţiuni de intrare/ieșire 
Grupa 6:.1/E blocuri de date — Intrare (input) multiplă 


Mnemonica generică : IN=R (INIR sau INDR) 


unde : x poate fi litera | sau D 
Total instrucţiuni sti 2 
Acţiunea : 


+ INIR — input, increment, repeat 
— INDR — input, decrement, repeat 


Conţinutul portului de intrare adresat prin conținutul registrului C, 
este transferat în celula de memorie adresată prin registrul dublu HL. 
Indicatorul de adresă HL este incrementat (INIR) sau decrementat 
(INDR) cu 1. Numărătorul de octeți B este decrementat cu 1. Ope- 
rația se repetă pînă cînd B=0. 

Necesar de memorie : 2 byte. 


Necesar de timp ; 21, (4,5,4,3,5) tacți procesor dacă după execuție Bz0 
16 (4,5,4,3) tacți procesor dacă după execuție B=0 
În ciclul de intrare, M3 (4 tacți procesor), starea magistralei de adrese 


este următoarea : 
A0 — A7 conținutul registrului C 


A8 — A15 conținutul registrului B decrementat 
Structura instrucţiunii : 
byte 0 byte 1 
Tipuri de adresare : destinaţie / sursă 
indirect / indirect 
Memento de cod : ÎNxR 


B0H_B! H B2H B3 HB4H B5H,B6 H,B7H,B8HB9 HBAHBBHBCHBOHBEH,BFH 


(LAZAR Ano 
LDIR CPIR BT LDDR CPDR TR 
Flaguri afectate ; S, H, P — necunoscute Z și N — devin 1] 
Cy — neafectat 
x[1 [x [x x ]xh [e] 
Exemple de utilizare : sz H PNCy 


386 


Z80 — ANALIZA INSTRUCȚIUNILOR 


INJOUT 


Clasa 11: Instrucţiuni de intrare/ieșire 
Grupa 7 : |/E blocuri de date — leşire (output) simplă 


Mnemonica generică : OUT. (OUTI sau OUTD) 


unde : x poate fi litera | sau D 


Total instrucţiuni iei ji 

Acţiunea : OUTI (out &increment) 
(C) — (HL) 
HL =HL+1 


B =B —1 
Conţinutul celulei de memorie adresată prin registrul dublu HL este 
transferat la portul de ieșire adresat prin conținutul registrului C. 
Indicatorul de adresă HL este incrementat cu 1. Numărătorul de octeți 
B este decrementat cu 1. 


OUTD (out&decrement) 


(C) + (HL) 
HL=HL+1 
B =8B —1 


ldem cu OUTI, dar cu deosebirea că indicatorul de adresă HL este 
decrementat cu 7. 

Necesar de memorie : 2 byte 

Necesar de timp ; 16 (4,5,3,4) tacți procesor 
În timpul ciclului out, M4 (4 tacți procesor), starea magistralei de 
adrese este următoarea : 
A0 — A7 conținutul registrului C 
A8 — A15 conţinutul registrului B decrementat 


Structura instrucţiunii : 
byte 0 byte 1 
Tipuri de adresare ; destinaţie | sursă 
indirect / indirect 

Memento de cod  OUlr: x 

i A Pre i AG 

ic CL a LDD CPD IND 

Flaguri afectate ; S, H,P — necunoscute, N — devine1, Cy — neafectat 


X[! [x [xxx [1 [e] 
SE A H PN Cy 


(27, dacă după execuţie B=0 


Z=0 dacă după execuţie Bz0 
Exemple de utilizare : vol. II, p. 210 Ș Îi a 


E.13. IN/OUT, DETALIAT 387 


IN/OUT 


Clasa 11: Instrucţiuni de intrare/ieșire 
Grupa 8.: |/E blocuri de date — leșire (output) multiptă 


Mnemonica generică : OT.R (OTIR sau OIDR) 


unde : x poate fi litera | sau D 
Total instrucţiuni Ca ci za 
Acţiunea : : 


! + OTIR — output, increment, repeat 
— OTDR — output, decrement, repeat 


Conţinutul celulei de memorie adresată prin registrul dublu HL este 
transferat în portul de ieșire adresat prin conținutul registrului C. 
Indicatorul de adresă HL este incrementat (OTIR) sau decrementat 
(OTDR) cu 1. Numărătorul de octeți este decrementat cu 1. Ope- 
rația se reia pînă cînd B=0. 

Necesar de memorie : 2 byte 

Necesar de timp ; 21 (4,5,3,4,5) tacți procesor dacă BZO 

16 (4,5,3,4)  tacți procesor dacă B=0 

În ciclul out, M4 (4 tacți procesor), starea magistralei de adrese este 
următoarea : 
AO — A7 conținutul registrului C 
A8 — A15 certinutul registrului B decrementat 


Structura instrucţiunii 
byte O byte 1 
Tipuri de adresare : destinaţie / sursă 
indirect / indirect 
Memento de cod : OTxR 


87H,B8H „89 H, BAH BB HBC H,BDH BE H,BFH 
eri 


LDIR CPR NR LDDR CPDR INDR 


Flaguri afectate _: 5. +-. P — necunoscute N, Z — devin 1 Cy — neafectat 
EDER EIEIEIEIESEI 
$ 2-5 PU. 


388 Z8B0 — ANALIZA INSTRUCȚIUNILOR 


Exemple de utilizare 


SYS 


Clasa 12: Instrucţiuni de comandă 


Grupa 1: Instrucţiunea HALT 


Mnemonica i HALT 


Total instrucțiuni | 


Acţiunea 


După execuția acestei instrucțiuni microprocesorul „se oprește": 
Se execută în continuare fetch-uri (care nu se iau în considerare)' 
pentru a se asigura reîmprospătarea memoriei dinamice, dacă este 
cazul, leșirea din această stare nu se poate face decît prin recepţia 
unei întreruperi sau a unui semnal de RESET. 


Necesar de memorie : 1 byte 


Necesar de timp ; 4 (4) tacţi procesor 


Structura instrucţiunii : 


Tipuri de adresare i — 


Memento de cod ; HALȚ 


cod :. 761 
Flaguri afectate : nici unul 
SZ H PNG 
Exemple de utilizare : vol. Il, p. 145 


389 


Clasa 12: Instrucţiuni de comandă SYS 


Grupa 2 : Stabilirea modului de întrerupere 


Mnemonita generică IM X 


unde : x poate fi 0, 1 sau 2 
Total instrucțiuni Ce pe 7 | ea) 


Acți unea 
Stabilește modul de întrerupere specificat : 


IM O 


— în acest mod dispozitivul care cere întreruperea va depune în ciclul 
de acceptare a întreruperii (interrupt acknowledge) pe magistrala de 
date codul unei instrucțiuni (de obicei CALL sau RST), Dacă instruc- 
țiunea astfel forțată are mai mulți octeți, dispozitivul întrerupător 
îi va livra și pe aceștia în cicluri mașină succesive. 


IM 1 


— în acest mod microrpocesorul execută automat o instrucțiune RST 
38H la acceptarea unei întreruperi. 


IM 2 


— dispozitivul care cere întreruperea furnizează un octet care va fi 
octetul inferior intr-o adresă intermediară. Octetul superior al adre- 
sei intermediare este furnizat de registrul |. Citind cele două celule 
de memorie succesive, începînd cu adresa specificată prin adresa 
intermediară, se obține adresa de salt la care se regăsește rutina de 
tratare a întreruperii respective. 


Necesar de memorie : 2 byte 

Necesar de timp -; 8 (4,4) tacţi procesor 

Structura instrucţiunii : 
byte 

Tipuri de adresare : implicit 

Memento de cod : IM x 


Flaguri afectate : nici unul 
Le Le |x Le [Xe Lele] 
SZ HF PNG 
Exemple de utilizare : vol. Il, p. 146 


390 Z80 — ANALIZA INSTRUCȚIUNILOR 


Clasa 12: Instrucţiuni de comandă 


Grupa 3 : Validarea și inhibarea sistemului de întreruperi 


x] EI sau DI) 


Mnemonica generică 


unde : x poate fi litera E sau D 


Total Instrucţiuni 


Acţiunea 


EI 


IFF1 =IFF2=1 


14+1=2 


SYS 


Sistemul de întreruperi se validează. El va fi apt să accepte o între- 
rupere după execuția primei instrucțiuni care urmează după El. Starea 
validată durează pînă la execuția primei instrucțiuni DI sau pînă la 


acceptarea primei cereri de întrerupere mascabilă. 


DI 


IFF1 =IFF2=0 


Sistemul de întrerupere se inhibă. Nu se mai acceptă cererile de 
întrerupere mascabilă ci doar cele nemascabile. Starea de inhibare 


poate fi suspendată prin execuția unei instrucțiuni EI. 


Necesar de memorie 


Necesar de timp 


Structura instrucţiunii 


Tipuri de adresare 


Memento de cod 


cod 


Flaguri afectate 


Exemple de utilizare 


E.14 SYS, DETALIAT 


1 byte 
4 (4) tacți procesor 
implicit 
x| (EI sau Dl) 


EI DI 
FBH F3H 


nici unul 


> Le xleIxlelele] 
sz n PRNUY 


vol. II, p. 149, p. 210 
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Clasa 12: Instrucţiuni de comandă 


Grupa 4 : Revenirea din rutinele de tratare a întreruperilor 


Mnemonica generică : REȚ x (REŢI sau REȚN) 


unde : x poate fi litera | sau N 


Total instrucțiuni șa (list Me2 


Acţiunea 
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RETI 


PClow + (SP) 
SP = SP+4+1 
PChigh + (SP) 
SP = SP+41 

! periferic Zilog 


Din virful stivei (SP) se încarcă adresa de revenire în contorul pro- 
gram PC. Circuitele periferice din familia Zilog sesizează această 
instrucțiune pentru a-și actualiza lista de priorități într-un sistem cu 
întreruperi multiple. (Este necesar a se executa instrucțiunea El 
înainte de RETI, pentru a se revalida întreruperile mascabile). 


RETN 
PClow + (SP) 
SP = SP+41 
PChigh «— (SP) 
SP = SP +1 
IFF1 «— IFF2 


Din vîrful stivei (SP) se încarcă adresa de revenire în contorul pro- 
gram PC. Conţinutul bistabilului IFF2 care a fost incărcat cu IFF1, 
se copiază înapoi în IFF1 pentru a se reface starea validată sau inhi- 
bată a întreruperilor mascabile. În ambele cazuri conținutul indicato- 
rului de stivă SP este incrementat cu 2. 


Z80 — ANALIZA INSTRUCȚIUNILOR 


Necesar de memorie : 2 byte 


Necesar de timp ; 14 (4,4,3,3) tacţi procesor 
Structura instrucţiunii 
Tipuri de adresare : adresa de revenire 
indirect 
Memento de cod : RET (RETI sau RETN) 
RETI RETN 
cod : 4DH 45H 

Flaguri afectate ; nici unul 

EI DEI EI EI EREI 

A H PN Cy 


Exemple de utilizare : vol. Il, p. 210 


SYS 


Clasa 12: Instrucţiuni de comandă 


Grupa 5 : Instrucţiunea NOP 


Mnemonica : NOP 


Total instrucțiuni ?.5] 

Acţiunea ; PC=PCj1 
Necesar de memorie : 1 byte 

Necesar de timp : 4 (4) tacţi procesor 


Structura Instrucțiunii : 


byte 


Tipuri de adresare i 
Memento de cod i NOP 


cod : 00H 


Flaguri afectate ; “nici unul 
e [e [x exe lee 
$ 4 H PN Cy 
Instrucţiunea NOP poate fi utilizată pentru a realiza temporizări ele- 
mentare. 


Exemple de utilizare 


lată 


F 


= 


LISTA INSTRUCȚIUNILOR MICROPROCESORULUI 


ke 


Z80 


Prezentul capitol constă din 2 liste care cuprind întregul set de instrucțiun 
al microprocesorului Z80: prima în ordinea alfabetică a mnemonicelor, a doua 
ordonată crescător după cod. 


Listele cuprind următoarele informaţii menţionate în antetul fiecărei pagini : 


În 


număr curent 

codul instrucţiunii 

mnemonica instrucţiunii 

indicatorii de condiţii (FLAG) 

numărul de cicluri mașină 

numărul de tacți procesor și repartizarea lor pe cicluri mașină 

timpul de execuţie al instrucţiunii în us pentru un microprocesor care 
funcționează cu un tacți de 2,5 MHz. 


cîmpul de comentarii se indică pagina la care se găsește descrierea detai- 


a instrucţiunii. 
Notaţii utilizate pentru flaguri : 


— Dax - 


— indicatorul este afectat conform rezultatului operației 

— indicatorul nu e modificat de operaţie 

— indicatorul e forțat în zero 

— indicatorul e forțat în unu 

— indicatorul e indiferent 

— indicatorul P/V e poziționat în conformitate cu depășirea rezultatului 
— indicatorul P/V e poziționat în conformitate cu paritatea rezultatului 
— conținutul bistabilului de întreruperi IFF1 


Pentru operanzi ai instrucțiunilor s-au folosit următoarele simboluri : 


N 


— un octet cu valoarea cuprinsă între 00H — OFFH 


NN  — doi octeți cu valoarea cuprinsă între 0000H — OFFFFH 
IND — deplasament ce se adună la conținutul unui registru index pentru 


obținerea adresei locației cu care lucrează instrucțiunea respectivă 


DIS — deplasament ce se adună la adresa de asamblare a instrucţiunii res- 


pective pentru a obține adresa de salt. 
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nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
1 8E ADC A,(HL) VIXIXVOI 2 7 (4,3) 2.80 
2 DD 8E 05 ADC  A,(IX+IND) |l!XIXVO! 5 19 (4,4,3,5,3) 7.60 
3 FD 8E 05 ADC  A,(IY+IND) |!X!XVOI 5 19 (4,4,3,5,3) 7.60 
4 SF ADC A,A VIXIXVO! 1 4 (4) 1.60 
3 88 ADC A,B VIXIXVO! 1 4 (4) 1.60 
6 89 ADC A,C VIXIXVO! 1 4 (4) 1.60 
7 8A ADC A,D VIXIXVO! 1 4 (4) 1.60 
8 8B ADC A,E VIXIXVO! 1 4 (4) 1.60 
Ş sc ADC A,H VIXIXVOI 1 4 (4) 1.60 
10 80 ADC A,L VIXIXVO! 1 4 (4) 1.60 
li CE 20 ADC A,N VIXIXVO! 2 7 (4,3) 2.80 
12 ED 4A ADC HL,BC 1IXIXVOI 4 15 (4,4,4,3) 6.00 
13 ED SA ADC HL,DE VIXIXVO! 4 15 (4,4,4,3) 6.00 
14 ED GA ADC HL,HL VIXIXVO! 4 15 (4,4,4,3) 6.00 
15 ED 7A ADC HL,SP VIXIXVOI 4 15 (4,4,4,3) 6.00 
16 86 ADD A,(HL) 1IXIXVO! 2 7 14,3) 2.80 
17 DD 86 05 ADD A,(IX+IND) 1!XIXVO! 5 19 (4,4,3,5,3) 7.60 
18 FD 86 05 ADD  A,(IY+IND) 1!XIXVOI 5 19 (4,4,3,5,3) 7.60 
19 87 ADD A,A VIXIXVOI 1 4 (4) 1.60 
20 80 ADD A,B VIXIXVO! 1 4 (4) 1.60 
21 81 ADD A,C VIXIXVO! 1 4 (4) 1.60 
22 82 ADD A,D VIXIXVO! 1 4 (4) 1.60 
23 83 ADD A,E VIXIXVO! 1 4 (4) 1.60 
24 ga ADD A,H VIXIXVO! 1 4 (4) 1.60 
25 85 ADD A,L VIXIXVO! 1 4 (4) 1.60 
26 C6 20 ADD A,N VIXIXVOI 2 7 (4,3) 2.80 
27 09 ADD HL,BC „„X1X.01 3 11 (4,4,3) 4.40 
28 19 ADD  HL,DE „„X1X.0! 3 11 (4,4,3) 4.40 
29 29 ADD HL,HL .„XIX.0! 3 11 (4,4,3) 4.40 
30 39 ADD HL,SP „.X1X.0! 3 11 (4,4,3) 4.40 
31 DD 09 ADD  IX,BC „„X1X.01 4 15 (4,4,4,3) 6.00 
32 DD 19 ADD  1X,DE „„XIX.0| 4 15 (4,4,4,3) 6.00 
33 DD 29 ADD  I1X,1X „„X1X.01 4 15 (4,4,4,3) 6.00 : 
34 DD 39 ADD  1X,SP „„XIX.01 4 15 (4,4,4,3) 6.00 
35 FD 09 ADD  IY,Bc "sX1X.01 8 15 (4,4,4,3) 6.00 
36 FD 19 ADD  1Y,DE „„XIX.01 4 15 (4,4,4,3) 6.00 
37 FD 29 ADD  I1Y,lY „„X1X.01 4 15 (4,4,4,3) 6.90 
38 FD 39 ADD  1Y,sP „.„XIX.0l 4 15 (4,4,4,3) 6.00 
39 A6 AND (HL) 11X1XPO0 2 7 (4,3) 2.80 
49 DD A6 05 AND  (IX+IND) 1IX1XPO0 5 19 (4,4,3,5,3) 7.60 
si FD A6 05 AND  (1Y+IND) 1IX1XPO0O 5 19 (4,4,3,5,3) 7.60 
42 A7 AND A 1IX1XPO0 1 4 (4) 1.60 
43 AO AND B 1IX1XPO0 1 4 (4) 1.60 
4a Ai AND C 1IX1XPO00 1 4 t4) 1.60 
45 A2 AND D 1IX1XPO0 1 4 (4) 1.60 
46 A3 AND E 11X1XP00 1 4 (4) 1.60 
47 A4 AND H 1IX1XPOO 1 4 (4) 1.60 
48 A5 AND L 11X1XPO00 1 4 (4) 1.60 
49 E6 20 AND N 1IX1XPO0 2 7 (4,3) 2.80 
50 CB 46 BIT 0,t(HL) XI!X1XX0. 3 12 (4,4,4) 4.80 
Si DD CB 05 46 BIT O0,(I1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
52 FD CB 05 46 BIT 0,(I1Y+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
53 CB 47 BIT 0O,A XIX1XX0. 2 8 (4,4) 3.20 
5a CB 40 BIT 0,B XIX1XX0. 2 8 (4,4) 3.20 
55 CB 41 BIT 0,c X!X1XX0. 2 8 (4,4) 3.20 
56 CB 42 BIT 0,0 XIX1XX0. 2 8 (4,4) 3.20 
57 CB 43 BIT 0,E X!X1XX0. 2 8 (4,4) 3.20 
58 CB 44 BIT 0,H X!IX1XX0. 2 8 (4,4) „38.20 
59 CB 45 BIT o0,L X!IX1XX0. 2 8 (4,4) 3.20 
60 CB 4E BIT 1,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
6i DD CB 05 4E BIT 1,(I1X+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
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62 FD CB 05 4E BIT 1,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
63 CB 4F BIT 1,A X!X1XX0. 2 8 (4,4) 3.20 
64 CB 48 BIT 1,B X!X1XX0. 2 8 (4,4) 3.20 
65 CB 49 BIT 1,C XIX1XX0. 2 8 (4,4) 3.20 
86 CB 4A BIT 1,0 X!IX1XX0. 2 8 (4,4) 3.20 
87 CB 4B BIT 1,E X!X1XX0. 2 8 (4,4) 3.20 
68 CB 4C BIT î,H X!X1XX0. 2 8 (4,4) 3.20 
69 CB 4D BIT îi,L X!X1XX0. 2 8 (4,4) 3.20 
70 CB 56 BIT 2,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
71 DD CB 05 56 BIT 2,(1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
72 FD CB 05 56 BIT 2,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
73 CB 57 BIT 2,A X!X1XX0. 2 8 (4,4) 3.20 
74 CB 50 BIT 2,8 X!X1XX0. 2 8 (4,4) 3.20 
75 CB Si BIT 2,c X!X1XX0. 2 8 (4,4) 3.20 
76 CB 52 BIT 2,0 XIX1XX0. 2 8 (4,4) 3.20 
77 CB 53 BIT 2,E X!X1XX0. 2 8 (4,4) 3.20 
783 CB 54 BIT 2,H X!X1XX0. 2 8 (4,4) 3.20 
79 CB 355 BIT 2,L X!X1XX0. 2 8 (4,4) 3.20 
80 CB SE BIT 3,(HL) XIX1XX0. 3 12 (4,4,4) 4.80 
8: DD CB 05 SE BIT 3,(1X+IND) XI!IX1XX0. 5 20 (4,4,3,5,4) 8.00 
82 FD CB 05 SE BIT 3,(1Y+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
83 CB SF BIT 3,A XIX1XX0. 2 8 (4,4) 3.20 
ga CB 58 BIT 3,B X!X1XX0. 2 8 (4,4) 3.20 
85 CB 59 BIT 3,c X!X1XX0. 2 8 (4,4) 3.20 
86 CB SA BIT 3,0 X!X1XX0. 2 8 (4,4) 3.20 
87 CB SB BIT 3,E X!IX1XX0. 2 8 (4,4) 3.20 
88 CB Sc BIT 3,H X!X1XX0. 2 8 (4,4) 3.20 
89 CB 5D BIT 3,L X!X1XX0. 2 8 (4,4) 3.20 
90 CB 66 BIT 4,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
91 DD CB 05 66 BIT 4,(IX+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
92 FD CB 05 66 BIT 4,(1Y+1IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
93 CB 67 BIT 4,A X!X1XX0. 2 8 (4,4) 3.20 
94 CB 60 BIT 4,B X!X1XX0. 2 8 (4,4) 3.20 
95 CB 61 BIT 4,C X!X1XX0. 2 8 (4,4) 3.20 
96 CB 62 BIT 4,0 X!X1XX0. 2 8 (4,4) 3.20 
97 CB 63 BIT 4,E X!X1XX0. 2 8 (4,4) 3.20 
98 CB 64 BIT 4,H X!X1XX0. 2 8 (4,4) 3.20 
99 CB 65 BIT 4,L XIX1XX0. 2 8 (4,4) 3.20 
100 CB 68E BIT S,(HL) XIX1XX0. 3 12 (4,4,4) 4.80 
101 DD CB 05 6E BIT S,(IX+IND) XI!X1XX0. 5 20 (4,4,3,5,4) 8.00 
102 FD CB 05 6E BIT 5,(1Y+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
103 CB 6F BIT S,A X!IX1XX0. 2 8 (4,4) 3.20 
104 CB 68 BIT S,B X!IX1XX0. 2 8 (4,4) 3.20 
105 CB 69 BIT S5,c XIX1XX0. 2 8 (4,4) 3.20 
106 CB 6A BIT 5,0 X!X1XX0. 2 8 (4,4) 3.20 
107 CB 6B BIT 5S5,E X!X1XX0. 2 8 (4,4) 3.20 
108 CB 6c BIT S,H X!X1XX0. 2 8 (4,4) 3.20 
109 CB 6D BIT S,L X!X1XX0. 2 8 (4,4) 3.20 
110 CB 76 BIT s6,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
111 DD CB 05 76 BIT 6,(1X+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
112 FD CB 05 76 BIT 6,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
113 CB 77 BIT 6,A X!X1XX0. 2 8 (4,4) 3.20 
114 CB 70 BIT €,B X!X1XX0. 2 8 (4,4) 3.20 
115 CB 71 BIT 6,C X!X1XX0. 2 8 (4,4) 3.20 
116 CB 72 BIT 6,0 X!X1XX0. 2 8 (4,4) 3.20 
117 CB 73 BIT 6,E XIX1XX0. 2 8 (4,4) 3.20 
118 CB 74 BIT s6,H X!X1XX0. 2 8 (4,4) 3.20 
119 CB 75 BIT 6,L X!X1XX0. 2 8 (4,4) 3.20 
120 CB 7E BIT 7,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
121 DD CB 05 7E BIT 7,(1X+IND) XI!IX1XX0. S5 20 (4,4,3,5,4) 8.00 
122 FD CB 05 7E BIT 7,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
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nr. cod mnemonica f lag nr. nr. timp comentarii 

crt sz h pnc cic tacti 2.5m 

123 CB 7F BIT 7,A XIX1XX0. 2 8 (4,4) 3.20 

124 CB 78 BIT 7,B XIX1XX0. 2 8 (4,4) 3.20 

125 CB 79 BIT 7,C X!X1XX0. 2 eg (4,4) 3.20 

126 CB 7A BIT 7,0 XIX1XX0. 2 eg (4,4) 3.29 

127 CB 7B BiT 7,E XIX1XX0. 2 8 (4,4) 3.20 

128 CB 7C BIT 7,H X!X1XX0. 2 8 (4,4) 3.20 

129 CB 7D BIT 7,L X!IX1XX0. 2 8 (4,4) 3.20 

130 DC BB AA CALL C,NN eX Xe, 5 17 (4,3,4,3,3) 6.80 DACA Cy=1 
3 10 t4,3,3) 4.00 DACA CY=0 

131 FC BB AA CALL M,NN she 5 17 t4,3,4,3,3) 6.80 DACA S =1 
3 10 (4,3,3) 4.00 DACA S =0 

132 D4 BB AA CALL NC,NN sedea 9 17 t4,3,4,3,3) 6.80 DACA CY=0 
3,410 14,3,32) 4.00 DACA CYy=1 

133 CD BB AA CALL NN se kuhae e 5 17 1(8,3,4,3,3) 6.80 

134 C4 BB AA CALL NZ,NN Mee eee d si 08, 3,4.3,3) 6.80 DACA 2 =0 
3 10 (4,3,3) 4.00 DACA 72 =i1 

135 FA BB AA CALL P,NN sk Xa "5 17 (4,3,4,3,3) 6.80 DACA Ss =0 
3 10 (4,3,3) 4.00 DACA S =1 

136 EC BB AA CALL PE,NN căi 5 17 120,9,4,3,3) 6.80 DACA P =i 
3 10 (4,3,3) 4.00 DACA P =0 

137 E4 BB AA CALL PO,NN se XX. 5 17 (4,3,4,3,3) 6.80 DACA P =0 
3 10 (4,3,3) 4.00 DACA P =1 

138 CC BB AA CALL Z,NN loa e e. e 9 09 K0,a,4,3,3) 6.80 DACA Z =1 
3 10 t4,3,3) 4.00 DACA Z =0 

139 3F CCF OO 74 4 (4) 1.60 

140 BE CP (NHL) VIXIXVII 2 7 (4,3) 2.80 

141 DD BE 05 + CP (1X+IND) 1!XIXVI! 5 19 (4,4,3,5,3) 7.60 

142 FD BE 05 CP UIY+IND) MIXIXViI! 5 19 (4,4,3,5,3) 7.60 

143 BF CP A VIXIXVI! 1 4 (4) 1.60 

144 B8 CP B VIXIXVI! 1 4 (4) 1.60 

145 B9 CP C VIXIXViI A 4 (4) 1.60 

146 BA CP D VIXIXViAI A 4 (4) 1.60 

147 BB CP E VIXIXVI! 1 4 (4) 1.60 Ă 

148 BC CP H MXIXVI! 1 4 (4) 1.60 

149 BD CP L VXIXVi! A 4 (4) 1.60 

150 FE 20 CP N VXIXViII 2 7 (4,3) 2.80 

151 ED A9 CPD IXIXI1. 4 16 (4,4,3,5) 6.40 

152 ED 89 CPDR VIXIXIL. 5 21 (4,4,3,5,5) 8.40 DACA BCHO SI AR(HL) 
4 16 (4,4,3,5) 6.40 DACA BC=0 SAU A=(HL) 

153 ED Ai CPI VIXIXIA. 4 16 (4,4,3,5) 6.40 

154 ED Bi CPIR ANCIȚI, -5 Ar RA,4,3,5,5) 8.40 DACA BCHO SI AH(HL) 
4 16 (4,4,3,5) 6.40 DACA BC=0 SAU A=(HL) 

155 2F CPL Pc n Pe IP | 4 (4) 1.60 

156 27 DAA 1IXILXP. 1 a 4 (4) 1.60 

157 35 DEC (HL» MIXIXVI. 3 11 (4,4,3) 4.40 

158 DD 235 05 DEC  (IX+IND) !1X!XVi. 5 23 (4,4,3,5,4,3) 9.20 

159 FD 35 05 DEC  (I1Y+IND) !1X!XVI. 6 23 (4,4,3,5,4,3) 9.20 

160 3D DEC A MXIXVI. 1 4 (4) 1.60 

161 05 DEC B VIXIXVA. 1 4 (4) 1.60 

162 OB DEC BC ri, 00 Cu ai | 6 (6) 2.40 

163 OD DEC Cc VIXIXVI. A 4 14) 1.60 

164 15 DEC 2 VIXIXVI. 1 4 (4) 1.60 

165 1B DEC DE ME 1 6 (6) 2.40 

166 1D DEC E VIXIXVA. i 4 (4) 1.60 

167 25 DEC H VIXIXVI. A 4 (4) 1.60 

168 28 DEC iL PE 0 e ORI d | 6 (6) 2.40 

169 DD 28 DEC 1X sole e "2 10 14,6) 4.00 

170 FD 23 DEC 1Y eX. 22 :10-4%,6) 4.00 

171 20 DEC L VIXIXVi. 1 4 (4) 1.60 

172 38 DEC SP „RI, Ci 6 (6) 2.40 

173 F3 DI au Mei ee 1 4 (4) 1.60 
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nr. cod mnemonica flag nr. nr. timp comentarii 

crt sz h pnc cic tacti 2.5m 

174 10 03 DINZ $+DIS peXekieu 3 1345,3,5) 5.20 DACA B 4 o 
2 8 (5,3) 3.20 DACA B=o0 

175 FB EI mm ela: d 4 (4) 1.60 

176 E3 EX (SP),HL mokXedlee m 5. 19414,3,4.3,5) 7.60 

177 DD E3 EX (SP),1X Xe X... 6 23 (4,4,3,4,3,5) 9.20 

178 FD E3 EX (5P),1Y ..XeXe.. 6 23 14,4,3,4,3,5) 9.20 

179 08 EX AF,AF” Vortatie 1 4 (4) 1.60 

180 EB EX DE,HL me edte e. Î 4 (4) 1.60 

181 ră EXX Pee 0 VOTE | 4 (4) 1.60 

182 76 HALT Pi e CNE | 4 (4 1.60 

183 ED 46 IM o mn% ekee e 2 8 (4,4) 3.20 

184 ED 56 IM 1 mă ala, 2 8 (4,4) 3.20 

185 ED SE IM 2 sisi% emise. 2 8 (4,4) 3.20 

186 ED 78 IN A,(C) VIX!XPO. 3 12 (4,4,4) 4.80 

187 DB 20 IN A, mel Wee Şi 11 +(4:38) 4.40 

188 ED 40 IN B,(C) VIXIXPO. 3 12 (4,4,4) 4.80 

189 ED 48 IN c,tc) 1IX!XPO. 3 12 (4,4,4) 4.80 

190 ED 50 IN D,(C) 1IXIXPO. 3 12 (4,4,4) 4.809 

191 ED 58 IN E,(C) 1IXIXPO. 3 12 (4,4,4) 4.80 

192 ED 60 IN H,(C) 1IXIXPO. 3 12 (4,4,4) 4.80 

193 ED 68 IN La) 1IXIXPO. 3 12 (4,4,4) 4.80 

194 34 INC (HL) 1IXIXVO. 3 11 (4,4,3) 4.409 

195 DD 34 05 INC  (IX+IND) 1IXIXVO. 6 23 (4,4,3,5,4,3) 9.20 

196 FD 34 05 INC  (1Y+IND) VIXIXVO. 6 23 (4,4,3,5,4,3) 9.20 

197 ac INC A VIXIXVO. îi 4 (4) 1.60 

198 04 INC B VIXIXVO. 1 4 1.60 

199 03 INC BC ek aăie ee i 6 t6) 2.40 

200 oc INC C VIXIXVO, 1 44) 1.60 

201 14 INC D VIXIXVO. 1 4 (4) 1.60 

292 13 INC DE se Xe ea Î 6 t6) 2.40 

293 1C INC E MIXIXVO. 1 4) 1.60 

204 24 INC H VIXIXVO. 1 4 wm 1.60 

205 23 INC HL ossis om A 6 (6) 2.40 

206 DD 23 INC IX ..XoXe., 2 10 (2,6) 4.00 

207 FD 23 INC 1Y XX... 2 10 (4,6) 4.09 

208 2C INC L VIXIXVO. 1 4 tt 1.60 

209 33 INC SP sapă pe es. A 6 (6) 2.40 

210 ED AA IND XIXXXX1. 4 16 (4,5,4,3) 6.40 

211 ED BA INDR X1XXXX1. 5 21 (4,5,4,3,5) 8.40 DACA Bt o 
4 16 (4,5,4,3) 6.40 DACA B =o0 

212 ED A2 INI XIXXXX1. 4 16 (4,5,4,3) 6.40 

213 ED B2 INIR X1XXXX1. 5 21 (4,5,4,3,5) 8.840 DACA B 80 
4 16 (4,5,4,3) 6.40 DACA B = 0 

214 E9 JP (HL) stea oa 1 4 (4) 1.60 

215 DD E9 JP (IX) mis RI es 2 8 (4,4) 3.20 

216 FD E9 JP (IY) oile as 2 8 (4,4) 3.20 

217 DA BB AA JP C,NN o Xale se 3: 10 44;3,3) 4.00 

218 FA BB AA AIP! M,NN stedlidla se 2 191843,93) 4.00 

219 D2 BB AA JP NC ,NN mm Fisa ve Ii 19494 3,3) 4.00 

220 C3 BB AA JP NN os %idle see 3: 10 14,3,3) 4.00 

221 C2 Ba AA JP NZ,NN vie oa se De AD Pa3+2) 4.00 

222 F2 BB AA JP P,NN e died se 3 10. 18233) 4.00 

223 EA.BB AA JP PE,NN vze Wise e 3... 10..18,3,3) 4.00 

224 E2 BB AA JP PO,NN sseXoKis em 3 19.14,3,3) 4.00 

225 CA BB AA DP. 2,NN vip Sotia e sm In 301433) 4.00 

226 38 03 JR C,$+DIS ve dă ve 8 12 44,3,59 4.80 DACA Cy=1 
2 7 44,3) 2.80 DACA CY=0 

227 18 93 JR $+D1S$ „data sie eee 3. 42343355) 4.509 

228 30 03 JR NC,S+DIS see Xe e. 3 12 0872;5) 4.80 DACA CY=0 
2 7 (4,3) 2.80 DACA Cy=i 

229 20 03 JR NZ,$+DIS visele 3 4204335) 4.80 DACA Z =9 


Z(ANIC 


F.l. LISTA MNEMONICELOR 399 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
2 7 (4,3) 2.80 DACA Z = 
230 28 093 JR 2,$+DIS sshehe a. 3 12(4,3,5) 4.80 DACA Z =i 
2 7 (4,3) 2.80 DACA Z =0 
231 02 LD (BC),A XX. 2 7 (4,3) 2.80 
232 12 LD (DE),A DE (eo OI 7 (4,3) 2.80 
233 77 LD (BL),A XX... 2 7 14,3) 2.80 
234 70 LD (HL),B ..XoX... 2 7 (4,3) 2.80 
235 71 LD (AL),C sila so e 2 7 (4,3) 2.80 
236 72 LD (HL),D XX, 2 7 t4,3) 2.80 
237 73 LD (HL),E XX... 2 7 (4,3) 2.80 
238 74 LD (BL),H e săehe ee „2 7 (4,3) 2.80 
239 75 LD (BL),L Do e DE 7 (4,3) 2.80 
240 36 20 LD (HL),N Xe X.., 3 10 (4,3,3) 4.00 
241 DD 77 05 LD CIX+IND),A ..X.X... 5 19 (4,4,3,5,3) 7.60 
242 DD 70 05 LD (IX+IND),B ..X.X... 5 19 (4,4,3,5,3) 7.60 
243 DD 71 05 LD CIX+IND),C ..X.X... 5 19 (4,4,3,5,3) 7.60 
244 DD 72 05 LD (IX+IND),D ..X.X... 5 19 (4,4,3,5,3) 7.60 
245 DD 73 05 LD (IX+IND),E ..X.X... 5 19 (4,4,3,5,3) 7.60 
246 DD 74 05 LD CIX+IND),H ..X.X... 5 19 (4,4,3,5,3) 7.60 
247 DD 75 05 LD (IX+IND),L ..X.X... 5 19 (4,4,3,5,3) 7.60 
248 DD 36 05 20 LD (IX+IND),N ..X.X... 5 19 (4,4,3,5,3) 7.60 
249 FD 77 05 LD (IY+IND),A ..X.X... 5 19 (4,4,3,5,3) 7.60 
250 FD 70 05 LD (IY+IND),B ..X.X... 5 19 (4,4,3,5,3) 7.60 
251 FD 71 05 LD (IY+IND),C ..X.X... 5 19 (4,4,3,5,3) 7.60 
252 FD 72 05 LD (IY+IND),D ..X.X... 5 19 (4,4,3,5,3) 7.60 
253 FD 73 05 LD (IY+IND),E ..X.X... 5 19 (4,4,3,5,3) 7.60 
254 FD 74 05 LD (IY+IND),R ..X.X... 5 19 (4,4,3,5,3) 7.60 
255 FD 75 05 LD (IY+IND),L ..X.X... 5 19 (4,4,3,5,3) 7.60 
256 FD 36 05 20 LD (IY+IND),N ..X.X... 5 19 (4,4,3,5,3) 7.60 
257 32 BB AA LD (NN),A XX... 4 13 (4,3,3,3) 5.20 
258 ED 43 BB AA LD (NN),BC ..X.X... 6 20 (4,4,3,3,3,3) 8.00 
259 EI 53 BB AA LD (NN),DE ..X.X... 6 20 (4,4,3,3,3,3) 8.00 
260 22 BB AA LD (NN),HL ..X.X..., 5 16 (4,3,3,3,3) 6.40 
261 ED 63 BB AA LD (NN),HL ..X.X... 6 20 14,4,3,3,3,3) 8.00 
262 DD 22 BB AA LD (NN), IX ..X.X... 6 20 (4,4,3,3,3,3) 8.00 
263 FD 22 BB AA LD (NN), 1Y XX... 6 20 (4,4,3,3,3,3) 8.00 
264 EL 73 BB AA LD (NN), SP ..X.X... 6 20 (4,4,3,3,3,3) 8.00 și 
265 OA LD A, (BC) Xe... 2 7 (4,3) 2.80 
266 1A LD A,(DE) kolo 2 7 44,3) 2.80 
267 7E LD A,(HL) osXoMe se. 2 7 (4,3) 2.80 
268 DD 7E 05 LD A, CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
269 FD 7E 05 LD A,CIY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
270 3A BB AA LD A, (NN) XX... 4 13 (4,3,3,3) 5.20 
271 7F LD A.A “sXXi.. i 4 (4) 1.60 
272 78 LD A,B pase i 4 (4) 1.60 
273 79 LD A,C eee. i 4 (4) 1.60 
274 7A LD A,D eo tc CORE | a (4) 1.60 
275 7B LD A,E Șase i 4 (4) 1.60 
276 7C LD A,H XX. i 4 (4) 1.60 
277 70 LD AL XX... i 4 (4) 1.60 
278 ED 57 LD A,1 1IXOXIO. 2 9 t4,5) 3.60 
279 3E 20 LD A,N SR ee. 2 7 t4,3) 2.80 
280 ED SF LD A,R 1IXOXI0. 2 9 (4,5) 3.60 
281 46 LD B,(HL) seXoX.e. 2 7 14,3) 2.80 
282 DD 46 05 LD B,(IX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
233 FD 46 05 LD B,(1Y+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
284 47 LD B,A euRae e 4 4 (4) 1.60 
285 49 LD B,B pase € a (4) 1.60 
286 41 LD B,C sedere d 4 (4) 1.60 
287 42 LD B,D art 00 Aa | 4 (4) 1.60 
288 43 LD B,E i 4 (4) 1.60 


..XeXeo.. 
Z — 696 INSTRUCȚIUNI DECLARATE 


D=] 
[=] 
[=] 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
289 aa LD B,H XX. 1 4 (4) 1.60 
290 45 LD B,L XX. 1 4 (4) 1.60 
291 06 20 LD B,N ..X.X... 2 7 14,3) 2.80 
292 ED 4B BB AA LD BC, (NN) ..X.X... 6 20 (4,4,3,3,3,3) 8.00 
293 01 BB AA LD BC,NN ..X.X... 3 10 t14,3,3) 4.00 
294  4E LD C,(HL) XX... 2 7 44,3) 2.80 
295 DD 4E 05 LD C,CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
296 FD 4E 05 LD C,CIY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
297 4F LD C,A XX. îi 4 (4) 1.60 
298 48 LD C,B XX... A 4 (4) 1.60 
299 49 LD C,c XX... A 4 (4) 1.60 
300 4A LD c,D XX. 1 4 (4) 1.60 
301 4B LD C,E XoXeee î 4 (4) 1.60 
302 4c LD c,H . .X.X... i 4 (4) 1.60 
303 40 LD c,L ..XoXase A 4 (4) 1.60 
304 0E 20 LD C,N XX. 2 7 (4,3) 2.80 
305 56 LD D,(AL) XX... 2 7 (4,3) 2.80 
306 DD 56 095 LD D,(1X+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
307 FD 56 05 LD D,(I1Y+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
308 57 LD D,A XX... 1 a (4) 1.60 
309 50 , LD D,B XX. A 4 (4) 1.60 
310 Si LD D,C XX. i 4 (4) 1.60 
311 52 LD D,D XX. A a t4) 1.60 
312 53 LD D,E . .XeXeo. i a ta) 1.60 
313 54 LD D,H XX. i 4 tm) 1.60 
314 55 LD D,L e că Co | 4 (4) 1.60 
315 16 20 LD D,N ..X.X... 2 7 (4,3) 2.80 
316 ED S5B BB AA LD DE, (NN) ..X.X..., 6 20 (4,4,3,3,3,3) 8.00 
317 11 BB AA LD DE,NN ..X.X..., 3 10 (4,3,3) 4.00 
3ie SE LD E,(HL) XX. 2 7 14,3) 2.80 
319 DD SE 05 LD E,(IX+IND) ..X.X..., 5 19 (4,4,3,5,3) 7.60 
320 FD SE 05 LD E,„(IY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
321 SF LD E,A XX 1 4 (m 1.60 
322 58 LD E,B XX... A a (4) 1.60 
323 59 LD E,C sola 1 4 (4) 1.60 
324 SA LD E,D XX. i 4 44) 1.60 
325 SB LD E,E XX. i 4 (4) 1.60 
326 Sc LD E,H ssXoXsee 1 4 (44) 1.60 
327 SD LD E,L să A a 14) 1.60 
328 LE 20 LD E,N ssăoXs: 2 7 (4,3) 2.80 
329 66 LD H, (BL) XX. 2 7 t4,3) 2.80 
330 DD 66 95 LD H,(CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
331 FD 66 95 LD H,(IY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
332 67 LD H.A XX... A 4 (4) 1.60 
333 60 LD H,B XX. i a (4 1.50 
334 61 LD H,C XX... i a (4) 1.60 
335 62 LD H,D XX. i atm 1.60 
336 63 LD H,E .sXoX... A a (4) 1.60 
337 64 LD H,H .sXeXs. i 4 (4) 1.60 
338 65 LD H,L .sXoXese A atm 1.60 
339 26 20 LD B,N XX... 2 7 (4,3) 2.80 
340 2A BB AA LD HAL, (NN) XX... 5 16 (4,3,3,3,3) 6.40 
341 ED 6B BB AA LD BL, (RN) ..X.X... 6 20 (4,24,3,3,3,3) 8.00 
342 21 BB AA LD BL,NN ..X.X..., 3 10 (4,3,3) 4.00 
343 ED 47 LD I,A sk. 2 9 (4,5) 3.60 
344 DD 2A BB AA LD IX, (NN) ..X.X... 6 20 (4,4,3,3,3,3) 8.00 
345 DD 21 BB AA LD 1X,NN „XX... 4 14 14,4,3,3) 5.60 
346 FD 2A BB AA LD 1Y, NN) ».X.X... 6 20 (4,4,3,3,3,3) 8.00 
347 FD 21 BB AA LD I1Y,NN „XX... 4 14 (4,4,3,3) 5.60 
348 6E LD L,(HL) „.X.X... 2 7 (4,3) 2.80 
349 DD 6E 05 LD L,CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 


F.1. LISTA MNEMONICEI 401 


nr. cod mnemonica f lag nr, nr. timp comentarii 

crt sz h pnc cic tacti 2.5m 

350 FD 6E 05 LD L, (IY+IND) Bokassa. 5, 19 (4.,4,3;343) 7.60 

351 SF LD L,A Re, cop, PE | 4 (4) "1.60 

352 58 LD L,B spXWeXese 1 4 (4) 1.60 

353 69 LD L,C Pe MR e a + 4 t4) 1.60 

354 GA LD L.D “XX 1 4 (4) 1.60 

355 6B LD L,E pa X 1 a ta) 1.50 

356 sc LD L,H .sXă 1 4 t4) 1.60 

357 6D LD L,L XX. 1 4 (4) 1.60 

358 2E 20 LD L,N XX... 2 7 (4,3) 2.80 

359 ED 4F LD R,A Fur, Sf, Pa 2 9 (4,5) 3.60 

360 ED 7B BB AA LD SP, (AN) sabia ee e „6. 20, 12,4,3,3,33) 8.00 

361 F9 LD SP,AL mă Xe 1 6 (6) 2.40 

362 DD F9 LD SP,1IX se%WekXes e 2, 10 (4,6) 4.00 

363 FD F? LD sP,1Y .. Xe Xe 2 10 (4,6) 4.00 

364 31 BB AA LD SP,NN sake Xe e Iu 10 (4,3,3) 4.00 

365 ED A8 LDD „X0X!0 4 16 (4,4,3,5) 6.40 

366 ED 88 LDDR «„X0X00. 5 21 (4,4,3,5,5) 8.40'DACA BC 4 0 
4 16 (4,4,3,5) 6.40 DACA BC = 0 

367 ED AO LDI „„X0X10. 4 16 (4,4,3,5) 6.40 

368 ED BO LDIR „„X0X00. 5 21 (4,4,3,5,5) 8.40 DACA BC 4 o 
4 16 (4,4,3,5) 6.40 DACA BC = 0 

369 ED 44 NEG MIXIXVI! 2 8 (4,4) 3.20 

370 00 NOP seXoXo ee i 4 (4) : 1.60 

371 B6 OR (HL) 11X0XPO0 2 7 (4,3) 2.80 

372 DD B6 05 OR (1X+IND) 11X0XPO0O 5 19 (4,4,3,5,3) „7.60 

373 FD B6 05 OR (IY+îN0) 11X0XPO0 5 19 (4,4,3,5,3) 7.60 

374 B7 OR A |!X0XPO0 1 4 (4) 1.60 

375 BO OR B 1IXOXPOO 1 4 (4) 1.60 

376 Bi OR LA 11X0XPO0 1 4 (4) 1.60 

377 B2 OR D 1!X0XPO0 1 4 (4) 1.60 

378 B3 OR E 1!X0XPO0O 1 4 (4) 1.60 

379 B4 OR H 1IX0XPO0 1 4 (4) 1.60 

380 B3 OR L |1X0XPO0 1 4 (4) 1.60 

381 F6 20 OR N 1!X0XPO0O 2 7 (4,3) 2.80 

382 ED BB OTOR X1XXXX1. 5 21 (4,5,3,4,5) 8.40 DACA BB 4 0 
4 16 (4,5,3,4) 6.40 DACA B =o0 

383 ED B3 OTIR X1XXXX1. 5 21 (4,5,3,4,5) 8.40 DACA Bt o 
4 16 (4,5,3,4) 6.40 DACA B = 0 

384 ED 79 OUT (C),A XX... 3 12 (4,4,4) 4.80 

385 ED 41 OUT (C),B ssX Xe 3 ile 14,4,4) 4.80 

3896 ED 49 DUT (C),c sedbeXi ao 3 ul 04,4,4) 4.80 

387 ED 5: DUT (C),D ne Xe e 3 ele 10.44.87 4.80 

388 ED 59 OUT (C),E aka: Jude AA, 8) 4.80 

389 ED ci DUT (C),H ..X-X... 3 12 (4,4,4) 4.80 

390 ED 6? 0UT (C),L ..X.X... 3 12 (4,4,4) 4.80 

391 D3 20 DUT (N),A *skeXos 3 Li t4,3,4) 4.40 

392 ED AB DUTD XIXXXX1. 4 16 (4,5,3,4) 6.40 

393 ED A3 QUTI XIXXXX1. 4 16 (4,5,3,4) 6.40 

394 Fi POP AF VIII 3 10 t4,3,3) „4.00 

395 Ci POP BC săi. 19 10 14,3,3) 4.090 

396 Di POP DE ssXeX.., 3 10 14,3,3) 4.00 

397 Ei POP HAL XX. 3 10 14,3,3) 4.00 

398 DD Ei POP IX sXX... 4 14 (4,2,3,3) 5.60 

399 FD Ei : POP I1Y XX... 4 14 t4,4,3,3) 5.60 

400 F5 PUSH AF seek 9 a 193,3) 4.40 

401 5 PUSH BC RX, 3 ii 15,3,3) 4.40 

402 D5 PUSH DE seXiXoee 3 13 (5,3,3) 4.40 

403 ES PUS! HL sakokesa 3 11 13,3,3) 4.40 

404 DD E5 PUSH 1X ..X.X... 4 15 t4,5,3,3) 6.00 

405 FD ES PUSH 1Y XX A 15'14,5,3,3) 6.00 

406 CB 86 RES 0,(HL) .. XX... 4 195 (4,4,4,3) 6.00 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 


„CIX+IND) ..X.X... 
1Y+IND) ..X.X... 


23 (4,4,3,5,4,3) 
23 (4,4,3,5,4,3) 


Li 


409 CB 87 RES ..XeXeo. 8 (4,4) . 
410 CB 80 RES XX... 8 (4,4) . 
411 CB 81 RES Xe Xe 8 (4,4) i 
412 CB 92 RES XX. 8 (4,4) . 
413 CB 83 RES XX... 8 (4,4) . 
414 CB 94 RES ..XeX... 8 (4,4) . 
415 CB 85 RES XX... 8 (4,4) . 
416 CB 8E RES HL) ..XoX.s. 15 (4,4,4,3) . 


417 DD CB 05 8E RES 
418 FD CB 05 8E RES 


IX+IND) ..X.X... 
IY+IND) ..X.X... 


23 (4,4,3,5,4,3) 
23 (4,4,3,5,4,3) 


419 CB 8Fr RES XX. 8 (4,4) . 
420 cB 88 RES .. XX... 8 (4,4) . 
421 CB 89 RES ..XoX. o. 8 (4,4) . 
422 CB 8A RES . Xe Xeo.. 8 (4,4) . 
423 CB 88 RES .. XX... 8 (4,4) . 
424 CB 8c RES XX... 8 (4,4) . 
425 CB 80 RES ..XeX. e. 8 (4,4) . 
426 CB 96 RES „(HL) XX... 15 (4,4,4,3) . 
427 DD CB 05 96 RES „C1X+IND) XX... 23 (4,4,3,5,4,3) . 
„C1Y+IND) ..X.X... 23 (4,4,3,5,4,3) . 
429 CB 97 RES . XX... 8 (4,4) . 
430 CB 90 RES , XX. 8 (4,4) . 
431 CB ?i RES . XX. 8 (4,4) . 
432 CB 92 RES Pi XX. 8 (4,4) 
433 CB 93 RES . Xeo. 8 (4,4) 
434 Ca 94 RES . Xe Xe. 8 (4,4) 
435 CB 95 RES . ..XoX... 8 (4,4) 
436 CB 9E RES „(HL) XX. 15 (4,4,4,3) 


IX+IND) ..X.X... 
1Y+IND) ..X.X... 


(4,4,3,5,4,3) 
23 (4,4,3,5,4,3) 


Lă 


Lă 


N88535585598835385385558595553555895853855585555555553555553358 
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428 FD CB 05 96 RES 2 
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439 CB 9F RES pi XX. 8 (4,4) 

440 CB 98 RES . XX... 8 (4,4) 

441 CB 99 RES . XX. 8 (4,4) 

442 CB SA RES . XX. 8 (4,4) 

443 CB 9B RES > ..X.X... 8 (4,4) B 
444 CB 9c RES . .. Xe Xoee. 8 (4,4) . 
445 CB 9D RES > BD 0 fi 8 (4,4) . 
446 CB A6 „RES 4,(HL) XX... 15 (4,4,4,3) . 
447 DD CB 05 A6 RES 4,(I1X+IND) ..X.X... 23 (4,4,3,5,4,3) . 
448 FD CB 05 A6 RES 4,(IY+IND) ..X.X... 23 (4,4,3,Ș,4,3) . 
449 CB A7 RES 4,A ..X.X. e 8 (4,4) . 
450 CB AO RES 4,8 Xe Xe. 8 (4,4) . 
451 CB AL RES 4,C XX... 8 (4,4) . 
452 CB A2 RES 4,0 Xe XX... 8 (4,4) . 
453 CB A3 RES 4,E Xe Xeo. 8 (4,4) . 
454 CB A4 RES 4,H Xe Xe 8 (4,4) . 
455 CB A5 RES 4,L ..XeXee. 8 (4,4) . 
456 CB AE RES S,(HL) .. XX... 15 (4,4,4,3) . 
457 DD CB 05 AE RES S,(IX+IND) ..X.X... 23 (4,4,3,5,4,3) . 
458 FD CB 05 AE RES S,(I1Y+iND) ..X.X... 23 (4,4,3,5,4,3) . 
459 CB AF RES S,A XX. 8 (4,4) . 
460 CB A8 RES S,B ..XeXes. 8 (4,4) . 
461 CB A9 RES sS,c .. Xe Xe... 8 (4,4) . 
462 CB AA RES S5,D Xe Xe. 8 (4,4) . 
463 CB AB RES S5,E XX... 8 (4,4) . 
464 CB AC RES S5,H XX... 8 (4,4) . 
4635 CB AD RES S,L XX. 8 (4,4) . 
466 CB 86 RES 6,(HL) XX. 15 (4,4,4,3) . 
467 DD CB 05 B6 RES 6,(IX+IND) ..X.X... 23 14,4,3,5,4,3) . 


A03 


F.1. LISTA MNEMONICELOR 


nr. cod mnemonica flag nr. nr. timp comentarii 


468 FD CB 05 B6 RES 6,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
469 CB B7 RES 6,A AX 2 ESI CALA) 3.20 
470 CB BO RES 6,B AXE, e 2 LE 00,4) 3.20 
471 CBBIi RES 6,c RX Di REA A) 3.20 
472 CB B2 RES 6,D ADI e 2 EBA.) 3.20 
473 CB B3 RES 6,E XIX 210 (8.4) 3.20 
474 CB B4 RES 6,H AXE, E 2 Tal lA,A) 3.20 
475 CB B5 RES 6,L MĂ Ste 2 NA ARIA) 3.20 
476 CB BE RES 7,(HL) Moe 4 15 (4,4,4,3) 6.00 
477 DD CB 05 BE RES 7,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
478 FD CB 05 BE RES 7,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
479 CB BF RES 7,A ML Oa 2 AB LA,AD) 3.20 
490 CB B8 RES 7,B Va Et 2 XB (4,4) 3.20 
481 CB B9 RES 7,C ANEXA 27 .FEL(A,4) 3.20 
482 CB BA RES 7,D RL e 2844, 3.20 
483 CB BB RES 7,E LX, E 3 KEIRA) 3.20 
484 CB BC RES 7,H AXR 2! XE (4,4) 3.20 
485 CB BD RES. 7,i LIRR e 2 XE ta) 3.20 
485 co RET VAR, e 3; MOTA(A,a.3) 4.00 
487 ns: RET C RAR 3 14 t5,3,8) 4.40 DACA CY=1 
1. 5 (5) 2.00 DACA CY=0 
28 re RET M LAMA i! 30 1158739 4.40 DACA s =1 
5 515) 2.00 DACA S =0 
489 Do RET NC SR a 3 ai (5,373) 4.40 DACA CY=0 
1 515) 2.00 DACA CY=1 
490 co RET NZ „LAB? 3 4 15,833) 4.40 DACA Z =0 
1 515) 2.00 DACA Z = 
491 FO RET P LL a 3 Mi (5,3,3) 4.40 DACA sS = 
: 1 515) 2.00 DACA Ss = 
492  E8 RET PE MR a Mali5,3,3) 4.40 DACA P = 
1 515) 2.00 DACA P = 
493  EO RET PO LIES, a BAR 45,299) 4.40 DACA P = 
1 515) 2.00 DACA P = 
494 ce RET Z ML 2 Ma (5,3,3) 4.40 DACA Z = 
1 515) 2.00 DACA Z = 
495 ED 40 RETI Le E Xe a 14 (4,4,3,3) 5.60 
496 ED 45 RETN XX A AAIIA,4,3,3) 5.60 
497 CB 16 RL  (HL) 1IXOXPO! 4 15 (4,4,4,3) 6.00 
498 DD CB 05 16 RL  (IX+IND)  L!!XOXPO! 6 23 (4,4,3,5,4,3) 9.20 
499 FD CB 05 16 RL  (IY+IND)  |!!XOXPO! 6 23 (4,4,3,5,4,3) 9.20 
500 CB 17 RL A 1!IXOXPO! 2 8 (4,4) 3.20 
501 CB 10 RL B VIXOXPO! 2 8 (4,4) 3.20 
502 CB ii RE <€ VIXOXPO! 2 8 (4,4) 3.20 L[cyle—7 =— 9] 
503  cB 12 RL DD VIXOXPO! 2 8 (4,4) 3.20 
504 CB 13 RL E VIXOXPO! 2 8 (4,4) 3.20 byte 
505 CB 14 îi Hi 1IXOXPO! 2 8 (4,4) 3.20 
506 CB 15 i i 1IXOXPO! 2 8 (4,4) 3.20 
507 17 RLA „XDX.0, 1.14 ca) 1.60 
508 CB 06 RLC (BL) 1IXOXPO! 4 15 (4,4,4,3) 6.00 
509 DD CB 05 06 BRLC (IX+IND)  !!XOXPO! 6 23 (4,4,3,5,4,3) 9.20 
510 FD CB 05 06 RLC (IY+IND)  !!X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
511 CB 07 RLC A 1!XOXPO! 2 8 (4,4) 3.20 
„512 : cB 00 RLC B 1IXOXPO! 2 8 (4,4) 3.20 
513 cBoOi RLC Cc 1IXOXPO! 2 8 (4,4) 3.20 7 o 
514 CB 02 RLC D VIXOXPO!: 2 8 (4,4) 3.20 
515  cB 03 RLC E 1!XOXPO! '2 8 (4,4) 3.20 byte 
516 CB 04 RLC H 1IXOXPO! 2 8 (4,4) 3.20 
517 CB 05 RLC L VIXOXPO! 2 8 (4,4) 3.20 
518 07 RLCA | „„X0X.0! 1 4 (4) 1.60 
519 EDF RLD 1IXOXPO. 5 18 (4,4,3,4,3) 7.20 [7-4 [3-0] [7-4]3-0 
520 CB 1E RR (BL) 1IXOXPO! 4 15 (4,4,4,3) 6.00 E 


nr. cod mnemonica flag nr, nr. timp comentarii 
crt sz h pnc cic tacti 2 .5m 

521 DD CB 05 1E RR  (IX+IND) 1IXOXPO! 6 23 (4,4,3,5,4,3) 9.20 

522 FD CB OS 1E RR  (IY+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 

523 CB AF RR A VIXOXPO! 2 8 (4,4) 3.20 

524 CB 18 RR B 1IXO0XPO! 2 8 (4,4) 3.20 X===—=—=—=— 
525 CB 19 RR C VIXOXPO! 2 8 (4,4) 3.20 Ucy-— 7 —— 0 
526 CB 1A RR D 11XOXPO! 2 8 (4,4) 3.20 bv 

527 CB AB RR E VIXOXPO! 2 8 (4,4) 3.20 Al: 

528 CB 1C RR H VIXOXPO! 2 8 (4,4) 3.20 

529 CB 1D RR L 1VIXOXPO! 2 8 (4,4) 3.20 

530  1F RRA j „.„X0X.0! 1 4 (4) 1.60 

531 CB OE RRC (HL) VIXOXPO! 4 15 (4,4,4,3) 6.00 

532 DD CB 05 0E RRC (IX+IND) 1IXOXPO! 6 23 (4,4,3,5,4,3) 9.20 

533 FD CB 05 0E RRC (IY+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 

534 CB OF RRC A 1IXOXPO! 2 8 (4,4) 3.20 

535  cBo8 RRC B VIXOXPO! 2 8 (4,4) 3.20 Ti 
536 CB 09 RRC C VIXOXPO! 2 8 (4,4) 3.20 |Cyjetel 7 —= 0 
537 CB OA RRC D 1IXOXPO! 2 8 (4,4) 3.20 byte 

538 CB OB RRC E 1IXOXPOI 2 8 (4,4) 3.20 

539 CB OC RRC _H 1IXOXPO! 2 8 (4,4) 3.20 

540 CB 0D RRC L 11!X0XPO! 2 8 (4,4) 3.20 

541  oF RRCA „„X0X.0! 1 4 (4) 1.60 — 
542 ED 67 RRD 11X0XPO. 5 18 (4,4,3,4,3) 7.20 [7-4[3-0) [7-4]3-0) 
543  c7 RST  00H sa-mi 3 11 8943.35 4.40 

544 cr RST 08H ek. 3 ii 4543.35 4.40 

545  D7 RST 10H XX 3 14 3:33) 440 A (HL) 
546  DF RST 18H XX. 2 Ei 0942.39 4.40 

547  E7 RST 20H shake 3 1 63:;343) 4.40 

548  _EF RST  28H „iXiă-ce 3 11 0543,33 4.40 

549  _F7 RST  30H ishi 3 11 4543,3) 4.40 

550 FF RST 38H eX 3 41.453) 4.40 

551  9E SBC A,(HL) VIXIXVI! 2 7 (4,3) 2.80 

552 DD 9E 05 SBC  A,(IX+IND) !!XIXVI! 5 19 (4,4,3,5,3) 7.60 

553 FD 9E 05 SBC  A,(IY+IND) M!XIXViI! 5 19 (4,4,3,5,3) 7.60 

554  9F SBC A,A VIXIXVII 1 4 (4) 1.60 

555 98 SBC A,B VIXIXVII 1 4 (4) 1.60 

556 99 SBC A,C VIXIXVII 1 4 (4) 1.60 

557  9A SBC A,D VIXIXVII 1 4 (4) 1.60 

558 98 SBC A,E VXIXVII 1 4 (4 1.60 

559 9 SBC A,H VXIXVII 1 4 (4 1.60 

560 90 SBC A,L VXIXVII 1 4 (4 1.60 

561 DE 20 SBC A,N VXIXVI!I 2 7 (4,3) 2.80 

562 ED 42 SBC  HL,BC VIXIXVI! 4 15 (4,4,4,3) 6.00 

563 ED 52 SBC  HL,DE VIXIXVI! 4 15 (4,4,4,3) 6.00 

564 ED 62 SBC HL,HL VIXIXVI! 4 15 (4,4,4,3) 6.00 

565 ED 72 SBC HL,SP VIXIXVII 4 15 (4,4,4,3) 6.00 

566 37 ScF „„X0X.01 1 4 (4) 1.60 

567 CB C6 SET 0,(HL) „DX A 15.44 ;8,4;a) 6.00 

568 DD CB 05 C6 SET 0,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 

569 FD CB 05 C6 SET 0,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 

370 CD 07 SET 0,A isa 2 9 i9saj 3.20 

571 CB co SET 0,B sokik-m 2 8.1.4) 3.20 

572 CB C1 SET 0,c săli 2 8 ăva) 3.20 

573 CB c2 SET 0,0 $săsă.s 2 89.644) 3.20 

574  cB ca SET 0,E văile. 2 3 (Av4) 3.20 

575 CB ca SET 0,H sala. 3 OB (ALA) 3.20 

576 CB C5 SET 0,L „XIX. 2 9 0Aâs 3.20 

577 CB CE SET 1,(HL) „săok.es 4 15 4Ara,4, 3) 6.00 

578 DD CB 05 CE SET 1,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 

579 FD CB 05 CE SET 1,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 

580 CB CF SET 1,A isXalea. 2 8.4474) 3.20 

581 ca cea SET 1,B saăză.g. 2 8.6454) 3.20 


Di 
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nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2 .5m 
582 CB Cc? SET îi,c su 2 8 (4,4) 3.20 
583 CB CA SET 1,0 seek 2 8 (4,4) 3.20 
584 CB CB SET" 1,E .sXoX.s 2 8 (4,4) 3.20 
585 CB cc SET 1,H "eX. Xi. 2 8 (4,4) 3.20 
586 CB CD SET 1i,L seăsăo ee 8 (4,4) 3.20 
587 CB D6 SET 2,(HL) XX... 4 153 (C4,4,4,3) 6.00 
588 DD CB 95 D6 SET 2,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
589 FD CB 05 D6 SET 2,(1IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
590 CB D7 SET 2,A DA, Ie aie + 8 (4,4) 3.20 
591 CB DO SET 2,8 cut St. Dr aia g (4,4) 3.20 
592 Ce Di SET '2,C peX Neue 2 8 (4,4) 3.20 
593 ca p2 SET 2,0 se oi : e 8 (4,4) 3.20 
594 CB D3 SET 2,E veXX. ss 2 8 (4,4) 3.20 
595 CB na SET 2,H Î XA I9. 2 8 (4,4) 3.20 
596 CB D5 SET 2,L XX... 2 8 (4,4) 3.20 
597 CB DE SET "3, CAL) XX... 4 15 (4,4,4,3) 6.00 
598 DD CB 05 DE SET 3,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
599 FD CB 05 DE SET 3,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
600 CB DF SET 3,A IRINA a 8 (4,4) 3.20 
601 CB 08 SET 3,B FIR Xp. ' € 8 (4,4) 3.20 
602 CB D9 SET 3,c „XX. 2 8 (4,4) 3.20 
603 CE DA SET 3,0 Pie e tr ae ae 8 (4,4) 3.20 
604 CB DB SET 3,E ARN a 8 (4,4) 3.20 
605 CB DC SET 3,H "E e 2 8 (4,4) 3.20 
606 CB DD SET '3,L dsăXuee e 8 (4,4) 3.20 
607 CB E6 SET 4,(H.) XX... 4 15 (4,4,4,3) 6.00 
508 DD CB 05 E6 SET 4,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
609 FD CB 05 E6 SET A4,(I1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
610 CB E7 SET A4,A SĂ. de 8 8 (4,4) 3.20 
611 CB EO SET 4,B să... 2 8 (4,4) 3.20 
612 CB Ei SET 4,c XX... 2 8 (4,4) 3.20 
613 CB E2 SET 4,D săi. 2 8 (4,4) 3.20 
Gia CB E3 SET 4,E veXeă.se 2 8 (4,4) 3.20 
615 CB E4 SET 4,H XX... 2 8 (4,4) 3.20 
616 CB ES SET 4,L IsXPĂ E. 2 8 (4,4) 3.20 
617 CB EE SET S,(HL) XX. 4 15 (4,4,4,3) 6.00 
6i8 DD CB 05 EE SET 5,(IX+1IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
619 FD CB 05 EE SET 5,(IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
620 CB EF SET S,A “XR. 2 8 (4,4) 3.20 
621 CB E8 SET 5,B ski 2 8 (4,4) 3.20 
622 CB E9 SET S5,C XX e 8 (4,4) 3.20 
623 CB EA SET 5,0 sXX.s. 2 8 (4,4) 3.20 
624 CB EB SET S5,E .. XX... 2 8 (4,4) 3.20 
625 CB EC SET S,H XX... 2 8 (4,4) 3.20 
626 CE ED SET S,L ..XeX... 2 8 (4,4) 3.20 
627 CB rs SET 6,(HL) ..XeXeo. 84 15 (4,4,4,3) 6.00 
628 DD CB 05 F6 SET 6,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
629 FD CB 05 Fe SET 6,(1Y+IND) ..X.X..,. 6 23 (4,4,3,5,4,3) 9.20 
630 CB F7 SET 6,A să 2 8 (4,4) 3.20 
631 CB FO SET 6,B ..X.X... 2 8 (4,4) 3.20 
632 CB Fi SET 6,c seX.X... 2 8 (4,4) 3.20 
633 CB Fr2 SET 6,0 XX... 2 8 (4,4) 3.20 
634 CB F3 SET 6,E ssXiX.s. 2 8 (4,4) 3.20 
635 CB Fa SET 6,H sshikee 2 8 (4,4) 3.20 
636 CE F5 SET s6,L „XX... 2 8 (4,4) 3.20 
637 CB FE SET 7,(HL) ..X.X... 4 15 (4,4,4,3) 6.00 
638 DD CB 095 FE SET 7,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
639 FD CB 05 FE SET 7,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
640 CB FF SET 7,A XX... 2 8 (4,4) 3.20 
641 CE Fe SET 7,B XX. 2 8 (4,4) 3.20 
542 CB F9 SET 7,c XX. 2 8 (4,4) 3.20 
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F.2. Lista în ordine crescătoare a codurilor 


L-C=-1 
nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2 .5m 
Ei 00 NOP > 0 Ii e | 4 (4) 1.60 
2 01 BB AA LD BC,NN sskeXaoe „3 101 14,3,3) 4.00 
3 02 LD (BC),A sXeXo ee 2 7 14,3) 2.80 
4 03 INC BC >ohekase si 6 (6) 2.40 
5 04 INC B VIXIXVO. 1 4 (4) 1.60 
6 05 DEC B VIXIXVI. 1 4 (4) 1.60 
7 06 20 LD B,N ..skXoXe o. 2 7 (4,3) 2.80 
i=i 07 RLCA „„X0X.0! 1 4 (4) 1.60 
9 08 EX AF „AF? ot 41 4 (4) 1.60 
10 09 p ADD HL,BC „„X1X.0! 3 11 (4,4,3) 4.40 
li OA LD A, (BC) see. 2 7 14,3) 2.80 
12 OB DEC BC pmXoXeoee A 6 (6) 2.40 
13 oc INC C VIXIXVO. 1 4 (4) 1.60 
14 0D DEC Cc VXIXVI. 1 44) 1.60 
15 0E 20 LD C,N alakos: 2 7 14,3) 2.80 
16 OF RRCA „„X0X.0! 1 4 (4) 1.60 
17 10 03 DINZ $+DIS asăeXoo 3 13 15+3,5) 5.20 DACA B 4 0 
2 8 (5,3) 3.20 DACA B = 0 
18 11 BB AA LD DE,NN pekekae e 3 10 (4.3.3) 4.00 
19 12 LD (DE),A heat 2 7 14,3) 2.80 
20 13 INC DE .XoXeo. 1 6 (6) 2.40 
21 14 INC D VIXIXVO. 1 4 (4) 1.60 
22 15 DEC D VIXIXVI. 1 4 (4) 1.60 
23 16 20 LD D,N esăeXea: „2 7 14,3) 2.80 
24 17 RLA „„X0X.0! 1 4 (4) 1.60 
25 18 03 JR $+D1S sake „3 la. (43335) 4.80 
26 19 ADD HL,DE „.„X1X.0! 3 11 (4,4,3) 4.40 
27 14 LD A, (DE) askeKao e 2 7 14,3) 2.80 
28 18 DEC DE sees si 6 (6) 2.40 
29 1c INC E VIXIXVO. 1 4 (4) 1.60 
30 10 DEC E VXIXVI. A 4 (4) 1.60 
31 1E 20 LD E,N seeks s ae 7 (4,3) 2.80 
32 AF RRA „„X0X.0! 1 4 (4) 1,60 
33 20 03 JR NZ,$+DIS sea» 33 12 (Aa3,5) 4.80 DACA Z =0 
ah 7 (4,3) 2.80 DACA Z =1 
34 21 BB AA LD HL,NN osXekas- «3 10 14,3;3) 4.00 
35 22 BB AA LD (NN) ,HL Xe Xeo 5 116 (4;3,343433 6.40 
36 23 INC HL DR aea mi 6 (6) 2.40 
37 24 INC H VIXIXVO. 1 4 (4) 1.60 
38 25 DEC H MXIXVI. 1 4 (4) 1.60 
39 26 20 LD H,N Se Xe E2 7 (4,3) 2.80 
40 27 DAA VNXIXP.I 1 4 (4) 1.60 
4 28 03 JR 2,$+DIS sees „3 12 14.3,5) 4.80 DACA Z =1 
pr 7 14,3) 2.80 DACA Z =0 
42 29 ADD HL,HL „„X1X.0! 3 11 (4,4,3) 4.40 
43 2A BB AA LD BL, (NN) sila ne 55 16.143; 3;8,31 6.40 | 
aa 2B DEC HL pe AR de | 6 (6) 2.40 
45 2C INC L 1IXIXVO. 1 44) - 1.60 
46 20 DEC L VXIXVI. A 4 (4) 1.60 
47 2E 20 LD L,N ceea X2 7 14,3) 2.80 
48 2F cPL se dă Rate rii 4 (4) 1.60 
49 30 03 JR NC,S$+DIS oa Wa LI A 13.3,3) 4.80 DACA CY=0 
2 7 (4,3) 2.80 DACA Cy=1 
50 31 BB AA LD SP ,NN seek e 22 20 49,3) 4.009 
Si 32 BB AA LD (UNND,A akku 32 13. 44;,3,3,3) 5,20 
52 33 INC SP rc OPRI ab | 6 (6) 2.40 
53 34 INC  (HL) VIXIXVO. 3 11 (4,4,3) 4.40 
s4 33 DEC  (HL) VIXIXVI. 3 11 (4,4,3) 4.40 
55 36 20 LD (AL),N Dede PI 10: 14,2,2) 4.00 
56 37 ScF „„X0X.01 1 4 (4) 1.60 
57 38 03 JR C,$+DIS veWakase 793 42 (4,3,5) i 4.80 DACA CY=i 
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nr. cod mnemonica f lag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
2 7 14,3) 2.80 DACA CY=0 
58 39 ADD HL,SP .„XIX.0] 3 11 (24,4,3) 4.40 
59 3A BB AA LD A, (NN) sskXeXs ee 4 13 (4,3,3,3) 5.20 
60 38 DEC  sP sees ss 6 (6) 2.40 
6i 3c INC A 1IXIXVO, 1 4 (4) 1.60 
62 30 DEC A VIXIXVI. 1 4 (4) 1.60 
63 3E 20 LD A,N sekedteeo 2 7 (4,3) 2.80 
64 3F CCF „„XXX.0! 1 4 (4) 1.60 
65 +40 LD B,B spkeXeo 1 4 (4) 1.60 
66 41 LD B,C ok Xe A 4 (4) 1.60 
67 42 LD B,D sie Wee A 4 (4) 1.60 
68 43 LD B,E o E | 4 (4) 1.60 
69 LL; LD B,H sis Xeez A 4 (4) 1.60 
70 45 LD BL spăla esa A 4 (4) 1.60 
71 46 LD B,(HL) XX 2 7 (4,3) 2.80 
72 47 LD B,A PD de a | 4 (4) 1.60 
73 48 LD C,B Xeo 4 (4) 1.60 
74 49 LD C,c ae Xe dU, e 4 (4) 1.60 
75 4A LD C,D vskeXses î 4 (4) 1.60 
76 48 LD C,E soWo es 3 4 (4) 1.60 
77 Ac LD C,H pista Xes 4 (4) 1.60 
78 40 LD c,L koku d 4 (4) 1.60 
79 4E LD C,(HL) pis Xe dDa aa. 88 7 (4,3) 2.80 
80 4F LD C,A ovkeba oa. A 4 (4) 1.60 
81 50 LD D,B Wee se A 4 (4) 1.60 
82 Si LD D,C pis dee os A 4 (4) 1.60 
83 52 LD D,D sk Xeoe d 4 (4) 1.60 
84 53 LD D,E sie ia Biecete SE 4 (4) 1.60 
85 54 LD D,H RE Po Pra | 4 (4) 1.60 
86 55 LD D,L sia d 4 (4) 1.60 
87 56 LD D,(HL) sk ss A 7 (4,3) 2.80 
88 57 LD D,A EA A DE AI | 4 (4) 1.60 
89 5e LD E,B paid e se. A! 4 (4) 1.60 
90 59 LD E,.C et i A IE | 4 (4) 1.60 
91 SA LD E,D ps doa A a (4) 1.60 
92 SB LD E,E ape Xeo A a (4) 1.60 
93 SC LD E,H pe. e, Ar AR | 4 (4) 1.60 
94 5D LD E,L sie ipae. A 4 (4) 1.60 
25 SE LD E,(HL) seo Due DUzes: + ad 7 (4,3) 2.80 
96 SF LD E,A “pi e AIE, | 4 (4) 1.60 
97 60 LD H,B ete 0 O | 4 (4) 1.60 
98 6i LD H,C Mae A 4 (4) 1.60 
99 62 LD H,D alia Xe aus. 4 (4) 1.60 
100 63 LD H,E E 00 DI | 4 (4) y 1.60 
101 64 LD R,H PE A hui! 4 (4) 1.60 
102 65 LD H,L pot <A AIE AT + 4 (4) 1.60 
103 66 LD H,(HL) E A AO PRR. 7 (4,3) 2.80 
104 67 LD H,A side Xe ee =: Îi 4 (4) 1.60 
105 58 LD L,B aa d > s 1 4 (4) 1.60 
106 69 LD L,€ A sto STR | 4 (4) „1.60 
107 GA LD L,D e 00 PE AU | 4 (4) 1.60 
108 6B LD LE pe pe ora | 4 (4) 1.60 
199 6C LD LH apte ip Sri! 4 (4) 1.60 
110 80 LD L,L e pb de: 1 4 (4) 1.60 
111 SE LD L,(HL) pt afin, dor, 7 (4,3) 2.80 
112 8F LD L,A pri: A dept | 4 (4) 1.60 
113 79 LD (HL),B PE: E ee Mr” 7 (4,3) 2.80 
î14 7i LD (HL),C PR CRT 7 (4,3) 2.80 
115 72 LD (HL),D 3% a: 2 7 (4,3) 2.80 
116 73 LD (HL),E săohoee 2 7 (4,3) 2.80 
117 74 LD (HL),H sole 2 7 (4,3) 2.80 
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nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
118 75 LD (HL),L e. XoXose 2 7 (4,3) 2.80 
119 76 HALT XX 1 4 (4) 1.60 
120 77 LD (HL),A XX: 2 7 14,3) 2.80 
121 78 LD A,B XX. i 4 (4) 1.60 
122 79 LD A,C XX. î 4 (4) 1.60 
123 7A LD A,D XX. i 4 (4) 1.60 
124 78 LD A,E vXoXose 1 4 (4) 1.60 
125 7C LD A,H soXeXses A 4 (4) 1.60 
126 7D LD A,L XX. i 4 t4) 1.60 
127 7E LD A, (BL) ssXeXos. 2 7 14,3) 2.80 
128 7F LD A,A sie Xse îi 4 (4) 1.60 
129 80 ADD A,B VIXIXVOI 1 4 (4) 1.60 
130 8: ADD A,C VIXIXVO! —1 4 (4) 1.60 
131 82 ADD A,D VIXIXVO! 1 4 (4) 1.60 
132 83 ADD A,E VIXIXVO! 1 4 (4) 1.60 
133 84 ADD A,H MIXIXVO! 1 4 (4) 1.60 
134 85 ADD A,L 1NXIXVO! 1 4 14) 1.60 
135 86 ADD A,(HL) 1IXIXVO! 2 7 (4,3) 2.80 
136 87 ADD A,A VIXIXVO! 1 4 (4) 1.60 
137 88 ADC A,B VIXIXVO! 1 4 (4) 1.60 
138 89 ADC A,C VIXIXVO! i 4 (4) 1.60 
139 8A ADC A,D VIXIXVO! 1 4 (4) 1.60 
140 8B ADC A,E MIXIXVO! 1 4 (4) 1.60 
141 8c ADC A,H VIXIXVO! 1 4 (â) 1.60 
142 80 ADC A,L MIXIXVO! 1 4 (4) 1.60 
143 8E ADC A,tHL) VIXIXVO! 2 7 (4,3) 2.80 
144 8F ADC A,A VIXIXVO! 1 4 (4) 1.60 
145 90 SUB B MIXNXVI! 41 4 (4) 1.60 
146 91 SUB Cc MIXIXVI! 1 4 (4) 1.60 
147 92 SUB D NIXIXVI! 1 4 (4) 1.60 
148 93 SUB E NIXIXVI! 1 4 (4) 1.60 
149 94 SUB H VIXIXVI!I 1 4 (4) 1.60 
150 95 SUB L VIXIXVI! 1 4 (4) 1.60 
151 96 SUB (BL) VIXIXViI! 2 7 (4,3) 2.80 
152 97 SUB A NXIXVI! A 4 (4) 1.60 
153 98 SBC A,B VIXIXVII 41 4 (4) 1.60 
154 99 SBC A,C NIXIXVI! 1 4 ta) 1.60 
155 9A SBC A,D VIXIXVi! 1 4 (4) 1.60 
156 9B SBC A,E NIXIXVAI A 4 (4) 1.60 
157 9c SBC A,H VXIXVi! 1 4 (4) 1.60 
158 90 SBC A,L VIXIXVI! 1 4 (4) 1.60 
159 DE SBC A,(HL) VXIXVI! 2 7 (4,3) 2.80 
160 9F SBC A,A VIXIXVI! 1 a (4) 1.60 
16: AO AND B 1IX1XPO0 1 4 (4) 1.60 
162 AL AND C€ 11X1XPO0 1 4 (4) 1.60 
163 A2 AND D VIX1XPOO 1 4 (4) 1.80 
164 A3 AND E 11X1XP00 i 4 (4) 1.60 
165 A4 AND H 1IX1XPO0 1 4 (4) 1.60 
166 A5 AND L 11X1XP00 1 4 (4) 1.60 
167 A6 AND  (HL) 1IX1XPO0 2 7 (4,3) 2.80 
168 A7 AND A 1IX1XPO0 1 4 (4) 1.60 
169 A8 XOR B 11X0XPO0 1 4 (4) 1.60 
170 A? XOR C 11X0XPO0 1 4 (4) 1.60 
171 LA XOR D 11X0XPO0 1 4 (4) 1.60 
172 AB XOR E 11X0XPO0 1 4 (4) 1.60 
173 AC XOR H 11X0XPO0O i 4 (4) 1.60 
174 AD XOR L 11X0XPO0 1 4 (4) 1.60 
175 AE XOR  (HL) 11X0XPOO0 2 7 (4,3) 2.80 
176 AF XOR A 11X0XPO0 1 4 (4) 1.60 
177 BO OR B 11X0XPO0 i 4 (4) 1.60 
178 Bi OR Cc 11X0XPO0 1 4 (4) 1.60 


410 Z80 — 696 INSTRUCȚIUNI DECLARATI 


nr. cod mnemonica t lag nr. nr. timp comentarii 

crt sz h pnc cic tacti 2.5m 

179 B2 OR D 11X0XPO0 1 4 (4) 1.60 

180 B3 OR E 11X0XPO0 1 4 (4) 1.60 

181 B4 OR H 11X0XPO0 1 4 (4) 1.60 

182 B5 OR L 11X0XPO0 1 4 (4) 1.60 

183 B6 OR (BL) 11X0XPO0 2 7 (4,3) 2.80 

184 B7 OR A 1IX0XPO0 1 4 (4) 1.60 

185 B8 CP B VIXIXVI! 1 4 (4) 1.60 

186 B9 CP Cc VXIXVI! 1 4 (4) 1.60 

187 BA CP D VIXIXVI! 41 a (4) 1.60 

188 BB CP E VIXIXViI A 4 (4) 1.60 

189 BC CP H VIXIXVII 1 4 (4) 1.60 

190 BD CP 5 MXIXVI! 1 a (4) 1.60 

191 BE CP (HL) VIXIXVI! 2 7 (4,3) 2.80 

192 BF CP A VXIXVII îi 4 (4) 1.60 

193 co RET NZ seăheXesa 3 11 (3,3.3) 4.40 DACA Z =0 
1 55 2.00 DACA Z =1i 

194 ci POP BC XX... 3 10 (4,3,3) 4.00 

195 C2 BB AA JP NZ ,NN s.XeXe.., 3 10 (4,3,3) 4.00 

196 C3 BB AA JP NN maXeXeee. -3 10 14,3,23) 4.00 

197 C4 BB AA CALL NZ2,NN ..X.X..., 5 17 (4,3,4,3,3) 6.80 DACA Z =0 
3 10 (4,3,3) 4.00 DACA 2 =1 

198 c5 PUSH BC ssXoXeee 3 ii (5,3,3) 4.40 

199 C6 20 ADD A,N 1IXIXVO! 2 7 (4,3) 2.80 

200 cC7 RST  00H XeXeee 3 11 (3,3,3) 4.40 

201 cea RET Z seX.X... 3 11 (5,3,3) 4.40 DACA Z =1 
Ş 5 (5) 2.00 DACA Z =0 

202 c9 RET ..X.X... 3 10 (4,3,3) 4.00 

203 CA BB AA JP 2,NN e.XeX... 3 10 (4,3,3) 4.00 

204 CB 00 RLC B 1IXOXPO! 2 8 (4,4) 3.20 

205 CB 01 RLC C 1IXO0XPO! 2 8 (4,4) 3.20 

206 CB 02 RLC D 1IXOXPO! 2 8 (4,4) 3.20 

207 CB 03 RLC E 1!X0XPO! 2 8 (4,4) 3.20 

208 CB 04 RLC H 1IX0XPO! 2 8 (4,4) 3.20 

209 CB 05 RLC L 11X0XPO! 2 e (4,4) 3.20 

210 CB 06 RLC (HL) 1IXOXPOI 4 15 (4,4,4,3) 6.00 

211 CB 07 RLC A |IXOXPO! 2 8 (4,4) 3.20 

212 CB 08 RRC B 1I!X0XPO! 2 e (4,4) 3.20 

213 CB 09 RRC C 11X0XPO! 2 8 (4,4) 3.20 

214 CB OA RRC D IIXOXPO! 2 8 (4,4) 3.20 

215 CB 0B RRC E |IX0XPO!I 2 8 (4,4) 3.20 

216 CB oc RRC AH 1IX0XPO! 2 8 (4,4) 3.20 

217 CB 0D RRC L 11X0XPO! 2 8 (4,4) 3.20 

218 CB 0E RRC  (HL) 11X0XPO! 4 15 (4,4,4,3) 6.00 

219 CB OF RRC A 11X0XPO! 2 8 (4,4) 3.20 

220 CB 10 RL B 1IX0XPO! 2 8 (4,4) 3.20 

221 CB ii RL C 1IXOXPO! 2 8 (4,4) 3.20 

222 CB i2 RL D 1IXOXPO! 2 8 (4,4) 3.20 

223 CB 13 RL E 1IXOXPO! 2 8 (4,4) 3.20 

224 CB 14 RL H VIXOXPO! 2 8 (4,4) 3.20 

225 CB 15 RL L 1IXOXPO! 2 8 (4,4) 3.20 

226 CB 16 RL (BL) |IXOXPO! 4 15 (4,4,4,3) 6.00 

227 CB îi7 RL A 11XO0XPO! 2 8 (4,4) 3.29 

228 CB 18 RR B 1IXOXPO! 2 8 (4,4) 3.20 

229 CB 19 RR Cc |IXOXPO! 2 8 (4,4) 3.20 

230 CB îiA RR D VIXOXPO! 2 8 (4,4) 3.20 

231 CB 18 RR E 1!IX0XPO! 2 8 (4,4) 3.20 

232 CB 1C RR Rn 1IXOXPO! 2 8 (4,4) 3.20 

233 CB 1D RR L 1IXOXPO! 2 8 (4,4) 3.20 

234 CB iE RR (AL) lIXOXPO! 4 15 (4,4,4,3) 6.00 

235 CB 1F RR A 1IXOXPO! 2 8 (4,4) 3.20 

236 CB 20 SLA B 1IXOXPO! 2 8 (4,4) 3.20 


F.2. LISTA CODURILOR 411 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
237 CB 21 SLA C 1IXOXPO! 2 8 (4,4) 3.20 
238 CB 22 SLA D 11X0XPO! 2 8 (4,4) 3.20 
239 CB 23 SLA E 1IX0XPO! 2 8 (4,4) 3.20 
240 CB 24 SLA H 11X0XPO! 2 8 (4,4) 3.20 
241 CB 25 SLA L 11X0XPO! 2 8 (4,4) 3.20 
242 CB 26 SLA  (HL) 1IXOXPO! 4 15 (4,4,4,3) 6.00 
243 CB 27 SLA A 11X0XPO! 2 8 (4,4) 3.20 
244 CB 28 SRA B 11X0XPO! 2 8 (4,4) 3.20 
245 CB 29 SRA C 1IX0OXPO! 2 8 (4,4) 3.20 
246 CB 2A SRA D 11X0XPO! 2 8 (4,4) 3.20 
247 CB 28 SRA E 11X0XPO! 2 8 (4,4) 3.20 
248 CB 2C SRA H |IXOXPO! 2 8 (4,4) 3.20 
249 CB 20 SRA L 1!IXOXPO! 2 8 (4,4) 3.20 
250 CB 2E SRA  (HL) VIXOXPO! 4 15 (4,4,4,3) 6.00 
251 CB 2F SRA A VIXOXPO! 2 8 (4,4) 3.20 
252 CB 38 SRL B IIXOXPO! 2 8 (4,4) 3.20 
253 CB 39 SRL Cc |!X0XPO! 2 8 (4,4) 3.20 
254 CB 3A SRL D 11X0XPO! 2 8 (4,4) 3.20 
255 CB 3B SRL E 11X0XPO! 2 8 (4,4) 3.20 
256 CB 3c SRL H 1IXOXPO! 2 8 (4,4) 3.20 
257 CB 30 SRL L 11X0XPO! 2 8 (4,4) 3.20 
258 CB 3E SRL (HL) |IXOXPO! 4 15 (4,4,4,3) 6.00 
259 CB 3F SRL A 11XOXPO! 2 8 (4,4) 3.20 
260 CB 40 BIT 0,B X!X1XX0. 2 8 (4,4) 3.20 
261 CB 41 BIT o0,c X!X1XX0. 2 8 (4,4) 3.20 
262 CB 42 BIT 0,0 X!X1XX0. 2 8 (4,4) 3.20 
263 CB 43 BIT 0,E X!X1XX0,. 2 8 (4,4) 3.20 
264 CB 44 BIT 0,H X!X1XX0. 2 8 (4,4) 3.20 
265 CB 45 BIT 0,L X!X1XX0. 2 8 (4,4) 3.20 
266 CB 46 BIT 0,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
267 CB 47 BIT O,A X!X1XX0. 2 8 (4,4) 3.20 
268 CB 48 BIT 1,8 X!X1XX0. 2 8 (4,4) 3.20 
269 CB 49 BIT î,c X!X1XX0. 2 8 (4,4) 3.20 
270 CB 4A BIT 1,0 X!IX1XX0. 2 8 (4,4) 3.20 
271 CB 48 BiT i,E X!X1XX0. 2 8 (4,4) 3.20 
272 CB 4c BIT îi,H X!IX1XX0. 2 8 (4,4) 3.20 
273 CB 40 BIT, 1,L X!X1XX0. 2 8 (4,4) 3.20 
274 CB 4E BIT 1,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
275 CB 4F BIT i,A X!X1XX0. 2 8 (4,4) 3.20 
276 CB 50 BIT 2,8 X!X1XX0. 2 8 (4,4) 3.20 
277 CB Si BIT 2,C X!X1XX0. 2 8 (4,4) 3.20 
278 CB 52 BIT 2,0 X!X1XX0, 2 8 (4,4) 3.20 
279 CB 53 BIT. 2,E X!X1XXO0. 2 8 (4,4) 3.20 
280 CB 54 BIT 2,H X!X1XX0. 2 8 (4,4) 3.20 
281 CB 55 BIT 2,L X1X1XX0. 2 8 (4,4) e psi 
282 CB 56 BIT 2,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
283 CB 57 BIT 2,A X!X1XX0. 2 8 (4,4) 3.20 
284 CB 58 BIT 3,B X1X1XX0. 2 8 (4,4) 3.20 
285 CB 59 BIT 3,c X!X1XX0, 2 8 (4,4) 3.20 
286 CB SA BIT. 3,0 X!X1XX0. 2 8 (4,4) 3.20 
287 CB S5B BIT 3,E X!X1XX0. 2 8 (4,4) 3.20 
288 CB SC BIT 3,H X!X1XX0. 2 8 (4,4) 3.20 
289 CB SD 2 să pate RL X!X1XX0. 2 8 (4,4) 3.20 
290 CB SE BIT 3,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
291 CB SF BIT 3,A XIX1XX0. 2 8 (4,4) 3.20 
292 CB 60 BiT 4,8 X!X1XX0. 2 8 (4,4) 3.20 
293 CB 61 BIT 4,C X!X1XX0, 2 8 (4,4) 3.20 
294 CB 62 BIT 4,0 XI!X1XX0. 2 8 t4,4) 3.20 
295 CB 63 BIT 4,E XIX1XX0. 2 8 (4,24) 3.29 
296 CB 64 BIT 4,H XIX1XX0, 2 8 (4,4) 3.20 
297 CB 65 BIT at XIX1XX0,. 2 a (4,4) 3.20 


der 
-— 
Lat] 


396 INSTRI ȚIUNI DECLARATI 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
298 CB 66 BIT 4,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
299 CB 67 BIT 4,A X!X1XX0. 2 8 (4,4) 3.20 
300 CB 68 BIT 5,B X!X1XX0. 2 8 (4,4) 3.20 
301 CB 69 BIT S5,c X!X1XX0. 2 8 (4,4) 3.20 
302 CB S8A BIT 5,0 X!X1XX0. 2 8 (4,4) 3.20 
303 CB 6B BIT S5,E X!X1XX0. 2 8 (4,4) 3.20 
304 CB 6C BIT S5,H X!X1XX0. 2 8 (4,4) 3.20 
305 CB 60 BIT -s5,L X!X1XX0. 2 8 (4,4) 3.20 
306 CB 6E BIT S5,(AHL) X!X1XX0. 3 12 (4,4,4) 4.80 
307 CB 6F BIT-'S,A X!IX1XX0. 2 8 (4,4) 3.20 
308 CB 70 BIT 6,B X!X1XX0. 2 8 (4,4) 3.20 
309 CB 71 BIT 6,c X!X1XX0. 2 8 (4,4) 3.20 
310 CB 72 BIT 6,0 X!X1XX0. 2 8 (4,4) 3420 
311 CB 73 BIT 6,E X!X1XX0. 2 8 (4,4) 3.20 
312 CB 74 BIT 6,H X!X1XX0. 2 8 (4,4) 3.20 
313 CB 75 BIT €6,L XIX1XX0. 2 8 (4,4) 3.20 
314 CB 76 BIT 6,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
315 CB 77 BIT 6,A X!X1XX0. 2 8 (4,4) 3.20 
316 CB 78 BIT 7,B X!X1XX0. 2 8 (4,4) 3.20 
317 CB 79 BIT + 7,C X!X1XX0. 2 8 (4,4) 3.20 
318 CB 7A BIT 7,0 X!X1XX0. 2 8 (4,4) 3.20 
319 CB 7B BIT 7,E X!X1XX0. 2 8 (4,4) 3.20 
320 CB 7C BIT: 7,H XIX1XX0. 2 8 (4,4) 3.20 
321 CB 7D BIT 7,L X!X1XX0. 2 8 (4,4) 3.20 
322 CB 7E BIT 7,(HL) X!X1XX0. 3 12 (4,4,4) 4.80 
323 CB 7F BIT 7,A X!X1XX0. 2 8 (4,4) 3,20 
324 CB 80 RES 0,B Sa hoXaie e 2 8 (4,4) 3.20 
325 CB 81 RES o0,c soWoXsae 2 8 (4,4) 3.20 
326 CB 82 RES 0,0 seek 2 8 (4,4) 3.20 
327 CB 83 RES 0,E soXeXie e 32 8 (4,4) 3.20 
328 CB 84 RES o0,H eX 2 8 (4,4) 3.20 
329 CB 85 RES o0,L meXoXaee a 8 (4,4) 3.20 
330 CB 86 RES  0,(HL) XX. 4 15 (4,4,4,3) 6.00 
331 CB 87 RES 0,A soXakpe e» “2 8 (4,4) 3.20 
332 CB 88 RES 1,B ..XoXe.. 2 8 (4,4) 3.20 
333 CB 89 RES 1,C Wake 12 8 (4,4) 3.20 
334 CB SA RES 1,0 seXsXue, 2 8 (4,4) 3.20 
335 CB 8B RES 1,E peXoXsee 2 8 (4,4) 3.20 
336 CB 8c RES 1,H seoXoXe.. “2 8 (4,4) 3.20 
337 CB 8D RES 1,L seXXse e. 2 8 (4,4) 3.20 
338 CB 8E RES 1.,(BL) XX. 4 15 (4,4,4,3) 6.20 
339 CB 8F RES 1,A fe WioXae 2 8 (4,4) 3.20 
340 CB 90 RES 2,8 eX Xe e, 2 8 (4,4) 3.20 
341 CB 91 RES 2,C so XsXase le 8 (4,4) 3.20 
342 CB 92 RES 2,0 poXeX ase 2 8 (4,4) 3.20 
343 CB 93 RES 2,E soXoXsee 2 8 (4,4) 3.20 
344 CB 94 RES 2,H seXoXsee 2 8 (4,4) 3.20 
345 CB 95 RES 2,L soXeXooe 2 8 (4,4) 3.20 
346 CB 96 RES 2,(HL) XX, 4 15 (4,4,4,3) 6.00 
347 CB 97 RES 2,A eX see 2 8 (4,4) 3.20 
348 CB 98 RES: 3,B gelu ai e “e 8 (4,4) 3.20 
349 CB 99 RES 3,c îeXeoXoee “2 8 (4,4) 3.20 
350 CB 9A RES 3,0 de VaĂ sis e 2 8 (4,4) 3.20 
351 CB 9B RES 3,E dalla 52 8 (4,4) 3.20 
352 CB 9C RES 3,H se WoXes e 2 8 (4,4) 3.20 
353 CB 90 RES 3,L soXoXee e 2 8 (4,4) 3.20 
354 CB 9E RES 3,(HL) soXXue. 3 15 14,4,4,3) 6.00 
355 CB 9F RES 3,A eXăXae e "2 8 (4,4) 3.20 
356 CB AO RES 4,B eokt + b2 8 (4,4) 3.20 
357 CB A1 RES 4,C peoRdă pe Fe 8 (4,4) 3.20 
358 CB A2 RES 4,0 eX Xe "2 8 (4,4) 3,20 


F2. LISTA CODURILOR i 413 


nr. cod mnemonica flag nr. nr. timp comentarii 
crt sz h pnc cic tacti 2.5m 
359 CB A3 RES 4,E îskXoXaee 2 8 (4,4) 3.20 
360 CB A4 RES a4,u eee 8 (4,4) 3.20 
361 CB A5 RES a,L pik e 8 (4,4) 3.20 
362 CB A6 RES 4,(HL) XX. 4 15 (4,4,4,3) 6.00 
363 CB A7 RES 4,A poa ks 8 (4,4) 3.20 
364 CB A8 RES S5,B a sXoXe.. 2 8 (4,4) 3.20 
365 CB A9 RES  S5,c XIX, 2 8 (4,4) 3.20 
366 CB AA RES 5,D sXeXee. 2 8 (4,4) 3.20 
367 CB AB RES S5,E îsXoXee. e 8 (4,4) 3.20 
368 CB AC RES  S5,H soXoXuee 2 8 (4,4) 3.20 
369 CB AD RES 5,L Pate a 8 (4,4) 3.20 
370 CB AE RES 5,(HL) Xe Xe. 4 15 (4,4,4,3) 6.00 
37i CB AF RES S,A ssXoXis e 8 (4,4) 3.20 
372 CB BO RES 6,B PINK, a 8 (4,4) 3.20 
373 CB Bi RES s6,c she Xise a 8 (4,4) 3.20 
374 CB B2 RES 6,0 eskoXoee 2 8 (4,4) 3.20 
375 CB B3 RES 6,E sii Kee “e 8 (4,4) 3.20 
376 CB B4 RES s6,H PX. 2 8 (4,4) 3.20 
377 CB B5 RES s6,L po e “2 8 (4,4) 3.20 
378 CB B6 RES 6,(HL) XX... 4 15 (4,4,4,3) 6.00 
379 CB B7 RES 6,A PIX “e 8 (4,4) 3.20 
380 CB B8 RES 7,B XX 2 8 (4,4) 3.20 
381 CB B9 RES 7,C ÎeXIRLi "e 8 (4,4) 3.20 
382 CB BA RES 7,D XX. “2 8 (4,4) 3.20 
383 CB BB RES  7,E XX. 2 8 (4,4) 3.20 
384 CB BC RES 7,H SoXeXoee 2 8 (4,4) 3.20 
385 CB BD RES 7,L doXWo Xe 2 8 (4,4) 3,20 
356 CB BE RES 7,(HL) XX. 4 15 (4,4,4,3) 6.00 
387 CB BF RES 7,A e săiXie 'e 8 (4,4) i 3.20 
388 CB CO SET 0,B pa kaki 2 8 (4,4) 3.20 
389 CB Ci SET 0,C ssXiXse "e 8 (4,4) 3.20 
390 CB c2 SET 0,0 XX. 2 8 (4,4) 3.20 
391 CB C3 SET 0,E seXeXoee 2 8 (4,4) 3.20 
392 CB ca SET 0,H fokoke, 2 8 (4,4) 3.20 
393 CB C5 SET  0,L ..X.X. 2 8 (4,4) 3.20 
394 CB C6 SET 0O,(HL) XX. 4 15 (4,4,4,3) 6.00 
395 CB C7 SET O0,A XX 2 8 (4,4) 3.20 
396 cB ca SET 1,8 PIRRE.. "2 8 (4,4) 3.20 
397 CB C9 SI 4 C să Xa 2 8 (4,4) 3.20 
398 CB CA S5BT 1,0 XX. 2 8 (4,4) 3.20 
399 CB CB SET 1,E XX 2 8 (4,4) 3.20 
400 CB CC SET 1,H SR Ne 2 8 (4,4) 3.20 
401 CB CD SET 1,L DX IX e 8 (4,4) 3.20 
402 CB CE SET 1,(HL) „XX 4 15 (4,4,4,3) 6.00 
403 CB CF SET 1,A dsăaliee e 8 (4,4) 3.20 
404 CB DO SET 2,B ..X.X... 2 8 (4,4) 3.20 
405 CB Di SET 2,Cc “XX... 2 8 (4,4) 3.20 
406 CB D2 SET 2,0 soX Xeo 2 8 (4,4) 3.20 
407 CB D3 SET 2,E .sXoXsee 2 8 (4,4) 3.20 
408 cB pa SET 2,H .. XX... 2 8 (4,4) 3.20 
409 CB D5 SET 2,L XX. 2 8 (4,4) 3.20 
410 CB D6 SET 2,(HL) „XX... 4 15 (4,4,4,3) 6.00 
ai CB 07 SET 2,A XX... 2 8 (4,4) 3.20 
412 CB 08 SET 3,8 XX. 2 8 (4,4) 3.20 
413 CB D9 SET 3,c XX. 2 8 (4,4) 3.20 
șia CB DA SET 3,0 XX... 2 9 (4,4) 3.20 
115 CB DB SET 3,E XX 2 8 (4,4) 3.20 
116 CB DC SET 3,H .sXoXeos. 2 8 (4,4) 3.20 
917 CB DD SET 3,L XX. 2 8 (4,4) 3.20 
118. CB DE SET 3,(HL) XX... 4 15 (4,4,4,3) 6.00 
119 CB DF SET 3,A ..XoX-e. 2 8 (4,4) 3.20 


414 780 — 696 INSTRUCȚIUNI DECLARATE 


nr. cod mnemonica f lag nr. nr. timp comentarii 

crt sz h pnc cic tacti 2.5m 

420 CB EO SET 4,B Xa Xs e 8 (4,4) 3.20 

421 CB E4 SET 4,C XX 2 8 (4,4) 3.20 

422 CB E2 SET 4,D XX £ 8 (4,4) 3.20 

423 CB E3 SET 4,E eX 2 8 (4,4) 3.20 

424 CB E4 SET 4,H XX 2 8 (4,4) 3.20 

425 CB E5 SET 4,L hăX. 2 8 (4,4) 3.20 

426 CB E6 SET 4,(HL) *.XeXee., 4 15 (4,4,4,3) 6.00 

427 CB E7 SET 4,A sie 8 (4,4) 3.20 

428 CB E8 SET S5,B e Sin oa 2 8 (4,4) 3.20 

429 CB E9 SET S5,C Re d 2 8 (4,4) 3.20 

430 CB EA SET $,D svXoXese 2 8 (4,4) 3.20 

431 CB EB SET .5.E săli 2 8 (4,4) 3.20 

432 CB EC SET S,H piăalaa 2 8 (4,4) 3.20 

433 CB ED SET 3,L sRoXses 2 8 (4,4) 3.20 

434 CB EE SET S,(HL) sfeX XX. o. 4 15 (4,4,4,3) 6.00 

435 CB EF SET S,A ooXeX.o.. 2 8 (4,4) 3.20 

436 CB FO SET 6,8 o XoXes. 2 8 (4,4) 3.20 

437 CB Fi SET 6,c XX... 2 8 (4,4) 3.20 

438 CB F2 SET 6,0 seXaXoee 2 8 (4,4) 3.20 

439 CB F3 SET 6.E XX 2 8 (4,4) 3.20 

440 CB FA SET s6,H spăXos 2 8 (4,4) 3.20 

441 CB F5 SET s6,L XX. 2 8 (4,4) 3.20 

442 CB F6 SET 6,(HL) ..X.Xoo.., 4 15 14,4,4,3) 6.00 

443 CB F7 SET 6,A 7 e 2 8 (4,4) 3.20 

444 CB F8 SET 7,B velo a 8 (4,4) 3.20 

445 CB F9 SET 7,C ste Rare 2 8 (4,4) 3.20 

446 CB FA SEŢ - 7,0 se Xe Xeo 2 8 (4,4) 3.20 

447 CB FB SET 7,E > 9 2 8 (4,4) 3.20 

448 CB FC SET -7,H XX 2 8 (4,4) 3.20 

449 CB FD SEŢ -7,L ot Fra Xe 2 8 (4,4) 3.20 

450 CB FE SET 7,(HL) XX 4 15 (4,4,4,3) 6.00 

451 CB FF SET 7,A „XX. 2 8 (4,4) 3.20 

452 CC BB AA CALL 2,NN RD o 5 17 (4,3,4,3,3) 6.80 DACA 2 =i 
3 410;44,3,3) 4.00 DACA Z =0 

433 CD BB AA CALL NN eX Xa 5 17 44,3,4,3,8) 6.80 

454 CE 20 ADC A,N VIXIXVO! 2 7 (4,3) 2.80 

455 CF RST O98H XX 3 11.-15,3,3) 4.40 

456 DO RET NC „X.X 3 1i.-t5,3,39 4.40 DACA CY=0 
i 5 (5) 2.00 DACA CY=i 

437 Di POP DE seem 23 109 14,3,3 4.00 

458 D2 BB AA JP NC,NN ssWeXese 3 10. 14,3,3) 4.00 

459 D3 29 0UT (ND,A Xeo Ko 3 11, 14,3,4) 4.40 

460 D4 BB AA CALL NC,NN vele 5 17 414,3,4,3,3) 6.80 DACA CY=0 
3 10 (4,3,3) 4.00 DACA CY=1 

461 D5 PUSH DE XX... 3 îi (3,3,3) 4.40 

462 D6 20 SUB N VIXIXVI! 2 7 (4,3) 2.80 

463 D7 RST 10H XX 3 11 (15,3,3) 4.40 

464 03 RET C seXoXoso 3 ii (5,3,3) 4.40 DACA CY=1 
1 5 (5) 2.00 DACA CY= 

465 n? EXX seo Xoee d 4 (4) 1.60 

466 DA BB AA JP C,NN sXoXus, 3 10 (4,3,3) 4.00 

467 DB 20 IN A,(N) vmXoXuee 3 Îi (4,3,4) 4.40 

468 DC BB AA CALL C,NN no Xe 5 17 44,3) 6.80 DACA CYy=1 
3 10 (4,3,3) 4.00 DACA CY=0 

469 DD 09 ADD  IX,BC „„X1X.0! 4 15 (4,4,4,3) 6.00 

470 DD 19 ADD  IX,DE „„X1X.0! 4 15 (4,4,4,3) 6.00 

471 DD 2i BB AA LD IX, NN sees 4 12 44,24,3,33 5.60 

472 DD 22 BB AA LD (NN), IX neko d 20 (4,4,3,3,3,33 8.00 

473 DD 23 INC  îX XX, 2 10 (4,6) 4.00 

474 DD 29 ADD  I1X,1X „„X1X.0! 4 15 (4,4,4,3) 6.00 

475 DD 2A BB AA LD IX, NN) *.X-X... 6 20 (4,4,3,3,3,3) 8.00 
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476 DD 28 DEC IX „XX, 2 10 4,8) 4.00 
477 DD 34 095 INC  (IX+IND) ŢIXIXVO. 6 23 (4,4,3,5,4,3) 9.20 
478 DD 35 05 DEC  (IX+IND) VIXIXVI. 6 23 (4,4,3,5,4,3) 9.20 
479 DD 36 05 20 LD (CIX+IND),N ..X.X... 5 19 (4,4,3,5,3) 7.60 
480 DD 39 ADD  IX,SP .„X1X.0! 4 15 (4,4,4,3) 6.00 
481 DD 46 05 LD B,(IX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
482 DD 4E 095 LD C,CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
483 DD 56 05 LD DIAIX+IND) ..XX... 5 19 14,4,3,5,3) 7.60 
484 DD SE 05 LD E,(IX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
485 DD 66 95 LD H,(IX+IND) ..X.X... 5 19 (4,4,3,5,3) 7,60 
486 DD 6E 05 LD L,(IX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
487 DD 70 05 LD (IX+IND),B ..X.X... SS 19 (4,4,3,5,3) 7.60 
488 DD 71 05 LD CIX+IND),C .,.X.X... 5 19 (4,;4,3,5,3) 7.60 
489 DD 72 095 LD (IX+IND),D ..X.X... 5 19 (4,4,3,5,3) 7.60 
490 DD 73 05 LD CIX+INDD),E XX. 5 19: 14,4;3,5,3) 7.60 
491 DD 74 95 LD (IX+IND),H XX... 5 1914,4,3,5,3) 7.60 
492 DD 75 095 LD (CIX+IND),L ..X.X... 5 19 (4,4,3,5,3) 7.60 
493 DD 77 05 LD (IX+IND),A ..X.X... SS 19 t4,4,3,5,3) 7.60 
494 DD 7E 95 LD A,CIX+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
495 DD 86 05 ADD A,CIX+IND) 1!XIXVO! 5 19 (4,4,3,5,3) 7.60 
496 DD 8E 95 ADC  A,CIX+IND) 1!X!XVO! 5 19 (4,4,3,5,3) 7.60 
497 DD 96 95 SUB  (IX+IND) VIXIXVI! 5 19 (4,4,3,5,3) 7.60 
498 DD SE 05 SBC  A,CIX+IND) M!X!XVi! 5 19 (4,4,3,5,3) 7.60 
499 DD A6 095 AND  (IX+IND) 1IX1XPO0 5 19 (4,4,3,5,3) 7.60 
500 DD AE 05 XOR  (IX+IND) 11X0XPO0 5 19 (4,4,3,5,3) 7.60 
501 DD B6 05 OR (IX+IND) 11X0XPO0 5 19 (4,4,3,5,3) 7.60 
502 DD BE 05 cP (IX+I1ND) IXIXVI! 5 19 (4,4,3,5,3) 7.60 
503 DD CB 05 06 RLC (IX+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
soa DD CB 05 0E RRC (IX+IND) 1IXOXPO! 6 23 (4,4,3,5,4,3) 9.20 
505 DD CB 05 16 RL (IX+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
506 DD CB 05 1E RR (IX+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
507 DD CB 05 26 SLA  (IX+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
508 DD CB 05 2E SRA (I1X+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
509 DD CB 05 3E SRL  (IX+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
310 DD CB 05 46 BIT 0,(IX+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
Si DD CB 05 4E BIT 1,(IX+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
312 DD CB 05 56 BIT 2,(1X+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
513 DD CB 05 SE BIT 3,(I1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
Sia DD CB 05 66 BIT 4,(IX+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
515 DD CB 05 6E BIT S5,(1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
516 DD CB 05 76 BIT 6,(1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
517 DD CB 05 7E BIT 7,(I1X+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
518 DD CB 05 86 RES 0,(I1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
519 DD CB 05 SE RES 1,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
520 DD CB 05 96 RES 2,(I1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
521 DD CB 05 9E RES 3,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
3522 DD CB 05 A6 RES 4,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
523 DD CB 05 AE RES 5,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
524 DD CB 05 B6 RES 6,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
5235 DD CB 05 BE RES 7,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
526 DD CB 05 C6 SET 0O,(I1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
527 DD CB 05 CE SET 1,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
528 DD CB 05 D6 SET 2,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
529 DD CB 05 DE SET 3,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
330 DD CB 05 E6 SET 4,(1X+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
534 DD CB 05 EE SET 5,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
532 DD CB 05 Fe SET 6,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
533 DD CB 05 FE SET 7,(IX+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
534 DD E1 FOP * 1X XX... 4 14 (4,4,3,3) 5.60 
535 DD E3 EX (SP),1X „XX... 6 23 (4,4,3,4,3,5) 9,20 
536 DD E5 PUSH IX SR Xe 3 43-10,5,3,2) 6.00 
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537 DD E9 JP (1X) salva 2 8 (4,4) 3.20 

538 DD F9 LD SP,IX XX... 2 10 (4,6) 4.00 

539 DE 20 SBC A,N VIXIXVi! 2 7 14,3) 2.80 

540 DF RST 18H sisăaleas 3 11;45.93,9) 4.40 

541 EO RET PO sokXaXoo» 93 11:15:3,3) 4.40 DACA P =0 
1 3 (5) 2.00 DACA P =1 

542 E1 POP HL ..X.X..., 3 10 (4,3,3) 4.00 

543 E2 BB AA JP PO,NN XX... 3 10 (4,3,3) 4.00 

544 E3 EX (SP),HL ssXeX.-, 5 19 (4,3,4,3,3) 7.60 

545 E4 BB AA CALL PO,NN Xe X... 5 17 (4,3,4,3,3) 6.80 DACA P =0 
3 10 (4,3,3) 4.00 DACA P =1 

346 ES PUSH HL XX, 3 11 (5,3,3) 4.40 

547 E6 20 AND N 11X1XP00 2 7 (4,3) 2.80 

548 E7 RST 20H »skakues 98 14,45,3.3) 4.40 

549 ES RET PE seXaXoea 3 11 (5,3.3) 4.40 DACA P =1 
i S (5) 2.00 DACA P =0 

550 E9 JP (BL) esXoXose î 4 (4) 1.60 

551 EA BB AA JP PE,NN ..XoX.-. 3 10 44,3,3) 4.00 

552 EB EX DE,HL XX i 4 (4) 1.60 

553 EC BB AA CALL PE,NN Xe Xeo, 5 17 (4,3,4,3,3) 6.80 DACA P =1 
3 10 (4,3,3) 4.00 DACA P =0 

554 ED 40 IN B,(c) 14X!XPO. 3 12 (4,4,4) 4.80 

555 ED 41 0UT (C),B ssXoXee. 3 12 (4,4,4) 4.80 

556 ED 42 SBC  HL,BC VIXIXVI! 4 15 (4,4,4,3) 6.00 

557 ED 43 BB AA LD (NN),BC »oXoX... 6 20 (4,4,3,3,3,3) 8.00 

558 ED 44 NEG VIXIXVI! 2 8 (4,4) 3.20 

55? ED 45 RETN XX... 4 14 (4,4,3,3) 5.60 

560 ED 46 1M o săi. 2 8 (4,4) 3.20 

561 ED 47 LD I,A XX... 2 9 (4,5) 3.60 

562 ED 48 IN Cc,t(c) 11X!XPO. 3 12 (4,4,4) 4.80 

563 ED 49 DUT (C),c ..XoXeo.., 3 12 (4,4,4) 4.80 

564 ED 4A ADC  HL,BC VIXIXVO! 4 15 (4,4,4,3) 6.00 

565 ED 48 BB AA LD BC, (NN) *„XeXes.. 6 20 (4,4,3,3,3,3) 8.00 

566 ED 40 RETI Xe Xeo, 4 14 (4,4,3,3) 5.60 

567 ED 4F LD R,A XX... 2 9 (4,5) 3.60 

568 ED 50 IN D,(C) 11X!XPO. 3 12 (4,4,4) 4.80 

569 ED Si 0UT (C),D ..X.Xe.., 3 12 (4,4,4) 4.80 

570 ED 52 SBC HL,DE VIXIXViI! 4 15 (4,4,4,3) 6.00 

571 ED 53 BB AA LD (NN),DE »XeX. o. 6 20 (4,4,3,3,3,3) 8.00 

972 ED 56 1M i XX. 2 8 (4,4) 3.20 

573 ED 57 LD AI 11X0XI0. 2 9 (4,5) 3.60 

574 ED 58 IN E,(C) 1IXI!XPO. 3 12 (4,4,4) 4.80 

575 ED 59 OUT (C),E ..X.X... 3 12 (4,4,4) 4.80 

576 ED SA ADC HL,DE MIXIXVO! 4 15 (4,4,4,3) 6.00 

577 ED SB BB AA LD DE, (NN) .. XX... 6 20 (4,4,3,3,3,3) 8.00 

578 ED SE 1M 2 sXoX... 2 8 (4,4) 3.20 

379 ED SF LD A,R 1IXOXIO. 2 9 (4,5) 3.60 

580 ED 60 IN H,(C) VIX!XPO. 3 12 (4,4,4) 4.80 

581 ED ci DUT (C),H XX... 3 12 (4,4,4) 4.80 

582 ED 62 SBC HL,HL VIXIXVI! 4 15 (4,4,4,3) 6.00 

383 ED 63 BB AA LD (NN),HL „„X.X... 6 20 (4,4,3,3,3,3) 8.00 

584 ED 67 RRD |!1X0XPO. 5 18 (4,4,3,4,3) 7.20 

585 ED 68 IN L,(c) 1IX!IXPO. 3 12 (4,4,4) 4.80 

586 ED 69 OUT (C),L XX... 3 12 (4,4,4) 4.80 

587 ED GA ADC HL,HL VIXIXVO! 4 15 (4,4,4,3) 6.00 

588 ED 6B BB AA LD HL, (NN) .sXoX.s. 6 20 (4,4,3,3,3,3) 8.00 

589 ED 6F RLD 11X0XPO. 5 18 (4,4,3,4,3) 7.20 

590 ED 72 SBC HL,SP IXIXVI! 4 15 (4,4,4,3) 6.00 

591 ED 73 BB AA LD (NN), SP * XX... 6 20 (4,4,3,3,3,3) 8.00 

592 ED 78 IN A,(C) VIXIXPO. 3 12 (4,4,4) 4.80 

593 ED 79 DUT (C),A ..XoX. o. 2 12 (4,4,4) 4.80 
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594 ED 7A ADC  HL,SP MIXIXVO! 4 15 (4,4,4,3) 6.00 

595 ED 7B BB AA LD SP, (NN) XX... 6 20 (4,4,3,3,3,3) 8.00 

596 ED AO LDI „„X0X10. 4 16 (4,4,3,5) 6.40 

597 ED A1 CPI VIXIXI1. 4 16 (4,4,3,5) 6.40 

598 ED A2 INI XIXXXX1. 4 16 (4,5,4,3) 6.40 

599 ED A3 0UTI X!XXXX1. 4 16 (4,5,3,4) 6.40 

600 ED A8 LDD „„X0X10. 4 16 (4,4,3,5) 6.40 

601 ED A9 CPD VIXIXI1. 4 16 (4,4,3,5) 6.40 

602 ED AA IND XIXXXX1. 4 16 (4,5,4,3) 6.40 

603 ED AB 0UTD X1XXXX1. 4 16 (4,5,3,4) 6.40 

604 ED BO LDIR „„X0X00. 5 21 (4,4,3,5,5) 8.40 DACA BC î 0 
4 16 (4,4,3,5) 6.40 DACA BC = 0 

605 ED Bi CPIR VIXLXI1. 5 21 t4,4,3,3,5) 8.40 DACA BC40 SI Ak(HL) 
4 16 (4,4,3,5) 6.40 DACA BC=0 SAU A=(HL) 

606 ED B2 INIR X1XXXX1. 5 21 (4,5,4,3,5) 8.40 DACA B 10 
4 16 (4,5,4,3) 6.40 DACA B =o0 

607 ED B3 OTIR X1XXXX1. 5 21 (4,5,3,4,5) 8.40 DACA B 10 
4 16 (4,5,3,4) 6.40 DACA B = 0 

608 ED B8 LDDR „„X0X00. 5 21 (4,4,3,5,5) 8.40 DACA BC 4 0 
4 16 (4,4,3,5) 6.40 DACA BC = 0 

609 ED B9 CPDR VIXIXI1, 5 21 (4,4,3,5,5) 8.40 DACA BCHO SI AH(HL) 
4 16 (4,4,3,5) 6.40 DACA BC=0 SAU A=(HL) 

810 ED BA INDR X1XXXX1, 5 21 (4,5,4,3,5) 8.40 DACA B 4 0 
4 16 (4,5,4,3) 6.40 DACA B =o0 

sii ED BB OTDR X1XXXX1. 5 21 (4,5,3,4,5) 8.40 DACA B 4% 0 
4 16 (4,5,3,4) 6.40 DACA B =o0 

612 EE 20 XOR N 11X0XPO0 2 7 (4,3) 2.80 

613 EF RST  28H Pele kees 3 11 13533) 4.40 

614 FO REJ P XX 3 11 13,3,3) 4.40 DACA S =0 
1 5' (5) 2.00 DACA Ss =1 

615 Fi POP AF VRMARULI 3 10 04,333 4.00 

616 F2 BB AA JP P,NN eX: 3 10:18,3;3) 4.00 

617 F3 DI Xe ee 1 4 (4) 1.60 

618 F4 BB AA CALL P,NN sooo 5 17 (4,3;4,3,3) 6.80 DACA S =0 
Ş 10't4,3;3h 4.00 DACA S =1 

619 F5 PUSH AF Veta, 3 11 15;3,3) 4.40 

620 F6 20 OR L.| 11X0XPO0O 2 7 (4,3) 2.80 

621 F7 RST  30H sEX Xe 3 Mi-t3,3+3) 4.40 

622 F8 RET M poXe Re 3 14 053,3) 4.40 DACA S =i 
5 5: t3) 2.00 DACA S =0 

623 F9 LD SP,HL XX. 1 6 (6) 2.40 

624 FA BB AA JP M,NN XX 3 10 (4,3,3) 4.00 

625 FB EI Wa A 4 (4) 1.60 

626 FC BB AA CALL M,NN boWakoae 5 47 44,3:4,3,3) 6.80 DACA s =i 

Y 3 10 (4,3,3) 4.00 DACA 5 =0 

627 FD 09 ADD  1Y,BC „X!X.0! 4 15 -14,4,4,3) 6.00 

628 FD 19 ADD  1Y,DE „„X1X.0! 4 15 (4,4,4,3) 6.00 

629 FD 21 BB AA LD 1Y ,NN uses. A 1% (4,403,39 5.60 

630 FD 22 BB AA LD (NN), 1Y seeks 8 20: 08,4,3,3,3,39 8.90 

631 FD 23 INC 1Y Xa, 2. 10" 04,6) 4.00 

632 FD 29 ADD  I1Y,IY „„X1X.0! 4 15 (4,4,4,3) 6.00 

633 FD 2A BB AA LD 1Y, (NN) eX Xa 6 20 64,433, 33) 8.00 

634 FD 2B DEC 1Y 1% Xa 2 10 (46) 4.00 

635 FD 34 05 INC  (IY+IND) 1IXIXVO. 6 23 (4,4,3,5,4,3) 9.20 

636 FD 35 05 DEC  (IY+IND) VIXIXVI. 6 23 (4,4,3,5,4,3) 9.20 

637 FD 36 05 20 LD CIY+IND),N ..X.X.. 5 19 (4,4,3,5,3) 7.60 

638 FD 39 ADD  1Y,SP „X1X.01 4 15 (4,4,4,3) 6.00 

639 FD 46 05 LD B,(IY+IND) ..X.X.. 5 19"04,4,3,5,3) 7.60 

640 FD 4E 05 LD CCIV+1ND) Xe 5 19 t4,4,3,5,3) 7.60 

63i FD 56 05 LD D,CIY+-IND) XX. 9 19: (4,4;3,5,3) 7.60 

642 FD SE 05 LD E,CIY+IND) ..X.X.. 5 19 (4,4,3,5,3) 7.60 
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643 FD 66 05 LD H,CIY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
644 FD 6E 05 LD L,CIY+IND) ..X.X... 5 19 t4,4,3,5,3) 7.60 
645 FD 70 095 LD (1Y+1IND),B ..X.X... 5 19 (4,4,3,5,3) 7.60 
646 FD 71 05 LD (IY+IND),C ..X.X..., 5 19 (4,4,3,5,3) 7.60 
647 FD 72 95 LD (1Y+1IND),D ..X.X... 95 19 (4,4,3,5,3) 7.60 
648 FD 73 05 LD (IY+IND),E ..X.X.., 5 19 (4,4,3,5,3) 7.60 
649 FD 74 05 LD CIY+IND),H .,.X.X... 5 19 (4,4,3,5,3) 7.60 
650 FD 75 05 LD CIY+IRD),L ..X.X..., 5 19 (4,4,3,5,3) 7.60 
651 FD 77 05 LD CIY+IND),A ..X.X... 5 19 (4,4,3,5,3) 7.60 
652 FD 7E 95 LD A,CIY+IND) ..X.X... 5 19 (4,4,3,5,3) 7.60 
653 FD 86 05 ADD  A,CIY+IND) !!X!XVO! 5 19 (4,4,3,5,3) 7.60 
654 FD 8E 05 ADC  A,(CIY+IND) !!X!XVO! 5 19 (4,4,3,5,3) 7.60 
655 FD 96 05 SUB  (IY+IND) XXVII! 5 19 (4,4,3,5,3) 7.60 
656 FD 9E 05 SBC  A,CIY+IND) !!X!XVI! SS 19 (4,4,3,5,3) 7.60 
657 FD A6 05 AND  (I1Y+IND) VIX1XPOO 5 19 (4,4,3,5,3) 7.60 
658 FD AE 05 XOR  (IY+IND) 11X0XPO0O 5 19 (4,4,3,5,3) 7.60 
659 FD B6 05 OR (IY+IND) 11X0XPO0 5 19 (4,4,3,5,3) 7.60 
660 FD BE 05 CP (IY+IND) VIXIXVII 5 19 (4,4,3,5,3) 7.60 
661 FD CB 05 06 RLC (IY+IND) |IXOXPO! 6 23 (4,4,3,5,4,3) 9.20 
662 FD CB 05 0E RRC (1Y+IND) |IXOXPO! 6 23 (4,4,3,5,4,3) 9.20 
663 FD CB 05 16 RL CIY+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
664 FD CB 05 1E RR (IY+1ND) 11XO0XPO! 6 23 (4,4,3,5,4,3) 9.20 
665 FD CB 05 26 SLA (I1Y+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
666 FD CB 05 2E SRA  (1Y+IND) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
667 FD CB 05 3E SRL  (1Y+INN) 11X0XPO! 6 23 (4,4,3,5,4,3) 9.20 
668 FD CB 05 46 BIT 0,(I1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
669 FD CB 05 4E BIT 1,(IY+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
670 FD CB 05 56 BIT 2,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
671 FD CB 05 SE BIT 3,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
672 FD CB 05 66 BIT 4,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
673 FD CB 05 6E BIT S5,(IY+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
674 FD CB 05 76 BIT 6,(1Y+IND) X!X1XX0. 5 20 (4,4,3,5,4) 8.00 
675 FD CB 05 7E BIT 7,(IY+IND) XIX1XX0. 5 20 (4,4,3,5,4) 8.00 
676 FD CB 05 86 RES 0,(I1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
677 FD CB 05 SE RES 1,(IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
678 FD CB 05 96 RES 2,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
679 FD CB 05 9E RES 3,(IY+IND) .,.X.X... 6 23 (4,4,3,5,4,3) 9.20 
680 FD CB 05 A6 RES 4,(I1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
681 FD CB 05 AE RES S,(îY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
682 FD CB 05 B6 RES 6,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
683 FD CB 05 BE RES 7,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
684 FD CB 05 C6 SET 0,(IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
695 FD CB 05 CE SET 1,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
686 FD CB 05 D6 SET 2,(1Y+I1ND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
687 FD CB 05 DE SET 3,(IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
688 FD CB 05 E6 SET 4,(IY+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
68? FD CB 05 EE SET S5,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9,20 
690 FD CB 05 F6 SET 6,(1Y+1IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
691 FD CB 05 FE SET 7,(1Y+IND) ..X.X... 6 23 (4,4,3,5,4,3) 9.20 
692 FD Ei POP 1IY Xe Xeo, 4 14 (4,4,3,3) 5.60 
693 FD E3 EX (SP),1Y ..X.X... 6 23 (4,4,3,4,3,5) 9.20 
694 FD ES PUSH 1Y XX... 4 15 (4,5,3,3) 6.00 
695 FD E9 JP (IY) Ă%o ss 2 8 (4,4) 3.20 
696 FD F9 LD SP,1Y pe XiXo se 2,110 44,6) 4.00 
697 FE 20 CP N VXIXVI! 2 7 14,3) 2.80 
698 FF RST  38H XX. 3 11 15,3,3) 4,40 
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INSTRUCŢIUNI ASCUNSE 
ALE MICROPROCESORULUI 780 


Studiind setul de coduri ale instrucțiunilor microprocesorului Z80 pot fi 
observate goluri. Inexistența unor instrucțiuni specificate i-a pus pe gînduri pe 
unii utilizatori ai acestei capsule, care abordînd problema empiric au descoperit 
o serie întreagă de coduri utilizabile, nedenumite și nepublicate de către fabri- 
canţi. Prima descoperire cunoscută nouă a realizat-o cercet. șt. Szâsz Detre la 
ITCI Filiala Cluj-Napoca. Codurile identificate și testate de dînsul se cifrează 
la 96. Publicate intern, ele au putut fi folosite de către programatorii institu- 
tului. 


Se pune întrebarea de ce fabricanţii, sau măcar proiectanţii microprocesorului 
Z80, nu au publicat existența acestor instrucţiuni ? Întrebarea rămîne deocam- 
dată deschisă. Încercările făcute în diverse țări pe loturi foarte variate (prove- 
nind de la diverse firme) au demonstrat că aceste instrucțiuni nu se execută 
aleator. Rezultă că ele își au originea în însuși proiectul inițial (măștile de fabri- 
cație) al circuitului integrat Z80. 


Fenomenul a fost între timp descoperit și la alte microprocesoare (ex.18086) 
şi s-a cristalizat o atitudine destul de unitară față de fenomenul instrucțiunilor 
ascunse. 


O povestim pe scurt: 

1. Existența unor instrucțiuni ascunse la unele procesoare este certă. 

2. Cert este că fabricanţii nu testează aceste instrucțiuni și deci nici nu-și 
asumă nici o răspundere pentru buna funcționare a microprocesorului în cazul 
folosirii lor. 

3. De obicei nu există asambloare, dezasambloare care să recunoască aceste 
instrucțiuni, care fiind descoperite în diverse părţi ale lumii poartă cele mai diver- 
se mnemonici pentru unul și același cod. Utilizatorul poate folosi aceste instruc- 
țiuni sub rezerva că ar putea apare un procesor al unui nou fabricant, care să 
nu suporte aceste instrucțiuni, caz în care software-ul va trebui să fie reconsi- 
derat. (Acest din urmă eveniment este puțin probabil în cazul microprocesorului 
Z80, el! aflîndu-se în fabricație deja de mai mult de un deceniu). 
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G.1. Prezentarea fenomenului. Mnemonici propuse. 


Instructiunile publicate de Szâsz Detre și totodată de către autor se referă 
la două fenomene : 

1, — posibilitatea tratării celor doi regiștri index IX, IY asemănător cu 
regiștri de uz comun, cum ar fi HL. S-a demonstrat că cei doi octeți ai unui regis- 
tru index pot fi tratați individual, efectuîndu-se transferuri și operații aritmetice/ 
logice cu ele. 


Propunem ca nume de argumente: XH — octetul superior al registrului IX 


XL — octetul inferior al registrului IY 
YH — octetul superior al registrului IY 
YL — octetul inferior al registrului IY 


Acești regiștri vor putea efectua următoarele 10 tipuri de operații aritme- 
tice/logice cu A: 


ADC,ADD,AND,CP,DEC,INC,OR,SBC,SUB,XOR 


obținîndu-se în total 40 de instrucțiuni. Codurile acestor instrucțiuni se obțin 
folosind unul din cele 2 coduri rezervate (DD pentru -X și fD pentru Y) și 
codul instrucțiunilor similare care folosesc regiștri H sau L. 


EXP 
ADC A,H are codul 8C 
ADC A,XH are codul DD 8C 
ADC A,YH are codul FD 8C 
XOR L are codul AD 
XOR XL are codul DD AD 
XOR YI are codul FD AD 


Setul se completează cu 40 de instrucțiuni de transfer interregistru. 


Ex: 


LD E,XH (DD 5C) 
LD YL,A (FD s6F) 


În fine XH,XL, YH şi YL pot fi încărcați cu valori prin instrucțiuni imediate 
cum ar fi: 


LD XH,nn (DD 2C nn) 


2. — posibilitatea efectuării unui nou tip de instrucțiune de deplasare la 
stînga : coriținutul registrului sau al celulei de memorie selectate se deplasează 
cu o poziție la stînga (D7 în Cy), iar pe bitul cel mai puţin semnificativ se 
inserează 1. Această instrucțiune execută de fapt operația (2*R+4-1), care poate 
fi utilă mai ales la implementarea unor funcții matematice. 


Menmonica propusă este SLH (Shift Left High) 
Ex. : 


SLH B are codul CB 30 
SLH (1X+IND) are codul DD CB IND 36 
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Totalul: acestor instrucțiuni se cifrează la 10, 
Obţinem astfel un set de 94 instrucțiuni ale căror date de funcționare se 
regăsesc în tabela G.2 (pag. 229—230). 


În afara acestor instrucțiuni, testate de autori, s-a publicat o nouă clasă 
numărînd 364 de instrucțiuni. 

Aceste instrucțiuni efectuează operații duble : 

— operație ROT/SHIFT urmată de transfer de date 

— operație SET/RES urmată de transfer de date 

Ele au fost descoperite pe aceeași cale intuitivă pornind de la observația 
că în lista originală a instrucţiunilor Z80 secvența de cod DD CB IND x, cuprinde 
doar posibilitatea utilizării unor valori x care au pe digitul cel mai puțin sem- 
nificativ cifra 6 sau E. 


EX,E 
DD CB IND 06 înseamnă RLC (1X+1IND) 


Încercînd diverse valori pentru x, altele decît cele prevăzute, s-a descoperit 
că ele generează activități interesante : rotirea celulei de memorie este urmată 
de transferul datei rotite într-un registru selectat. S-a demonstrat astfel că setul 
publicat de fabricanți este un caz particular, în care transferul se efectuează în 
însăși celula adresată prin (IX+IND) sau (IY+IND). 

Rezultatul instrucţiunii poate fi dirijat în afara celulei de memorie indexate 
în unul din regiștri A,B,C,D,E,H sau L. 

Pe această cale s-au identificat funcții similare pentru instrucțiuni de tip 
RES și SET. 
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RR (IY+IND),E are codul FD CB IND 1B 
SET 5, (IX+IND),A are codul DD CB IND EF 


În tabela G.1, sintetizăm aceste instrucțiuni ascunse, menţionînd că primele 
8 coduri din coloana (IX+d) sînt recunoscute și publicate de firme. 

Formatul general al codurilor va fi : 

pentru (IX+d) : DD CBdx 

pentru (IY+d) : FD CBdx 
— valoarea lui x se ia din tabela G.1. 
— d reprezintă deplasamentul (indicele). 

Remarcăm absența codurilor 40 —7F care ar reprezenta instrucțiuni de 
tip BIT. Lăsăm pe seama cititorului să încerce acest set de coduri. 

Autorul a testat cîteva din instrucțiunile tabelei C1. Ele par a fi într-adevăr 
corecte. 

Astfel totalul instrucțiunilor acceptate de microprocesorul Z80 crește cu: 
94 + 364 = 458, față de cele 696 publicate. - 
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Tabela G.f. instrucţiuni de manipulare a celulelor de memorie indexate, urmate de transfer: 


în registru 
r ia < + at H LL O(0X+IND)A 

RLC (UX+d)ur 00 01 02 03 04 03 06 07 
RRC (UX+-d),r 08 09 0A OB 0C 00 OE OF 
RL (X+d),r 10-94. 93: Păi Me m45 16 17 
RR (X+d),r E E, E 7 e: e 1E 1F 
SLA (IX + dr IE, TIE > a, mi le: 26 27 
SRA (XX +d)r 20 29 34 38-30-40 2e 2F 
SLH (X+d),r 30. 31 37 5 3% 37 
SRL (0X+-d),r 38 39 3A 38 3C 3D 3£ 3F 
RES 0,(1X-+-d),r 80 81 82 83 84 85 86 87 
RES 1,(0X+d),r 88 89 8A 88 8 80 8E 8F 
RES 2,(1X +d),r 90 91 92 93 94 95 96 97 
RES 3, (UX = d)r 98 99 9A 9B 9C 9D 9E 9F 
RES 4(0X d) AO A1 A2 A3 A4 AS A6 A7 
RES 5, (IX +d),r AB  A9 AA AB AC AD AE AF 
RES 6,(1X d), BO B1  B2 B3 84  B5 86 87 
RES 7.U0X d) B8 89 BA BB BC BD BE BF 
SET 0,(1X+d),r CĂ. Ci Că CR 0. Cs C6 C7 
SET 1,(0X+d),r CA 09. Ci Ba EEE Ep CE CF 
SET 2,(0X+d),r 00 Di 02 03 pa .D5 D6 D7 
SET 3, (X+d),r D8 D9 DA DB DC DD DE DF 
SET 4, (IX+d),r EO E1 E2 E3 E4  E5 E6 £7 
SET 5, (IX +d)r E E9 EA EB EC ED EE EF 
SET 6,(IX+d),r FO F1  F2  F3  F4  F5 F6 F7 


SET 7 (0X+d)r F8 F9 FA FB FC FD FE FF 


Ip INTREPRINDEREA POLIGRAFICĂ CLUJ, 
2 Municipiul Cluj-Napoca, B-dul Lenin, nr. 146. 
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. L. Dumitrașcu 


„A. Petrescu şi colectiv IPB, 


ITCI, Fabrica de calculatoare, 
Liceul Dimitrie Cantemir, 
CNOP 


„A. Tănăsescu și colectiv IPB, 


ISPIF 2 


Colective largi 


„A. Davidoviciu și colectiv 


ITCI, ASE 


1. Văduva, V. Baltac, 
Florescu V şi colectiv ASE, ITCI 


. Rusu O., Brudaru |. 


„P. Constantinescu 


Invăţăm  microelectronică interactivă 
conversind în BASIC. Totul despre... 
BASIC în 14 conversații și 7 sinteze 
pt Felix C, CORAL, INDEPENDENT, 
Felix PC, M118, TPD, HC. 85, aMIC, 
PRAE, COMMODORE, AMSTRAD şi 
compatibile, vol. 1 și 2. 


ABC de calcul electronice Totul des- 
pre... HC 85, vol. 1, și vol. 2, (e parte 
a tirajului cu 2 casete cu programe, 
acționind calculatoare personale HC 85 
și compatibile SINCLAIR SPECTRUM) 


Grafică asistată de calculator: Programe 
Fortran pe minicalculatoare, pentru re- 
prezentări geometrice, vol. 1 și vol. 2. 


Automatică, management, calculatoare 
(AMO). Serie continuă de instruire, in- 
formare, sinteze, cercetări aplicative în 
sisteme electronice, automate, informa- 
tice, de conducere, volumele 56—51. 
Echipamente electronice şi tehnică de 
calcul — manuale de utilizare. Calcu- 
latoare personale, programe ș.a. 


Sistemul de operare MIX și limbajul 
MACRO pentru minicalculatoare CO- 
RAL/INDEPENDENT, 2 volume. 


Informatică economică, 2 volume 


Echilibrarea liniilor flexibile. 


Sinergia, informaţia și geneza sistemelor. 


Se difuzează prin unităţile centrelor de librării, spre care se îndrumă întreprin- 


derile și cititorii. A 
PENTRU ACESTE CARŢI SE 


POT FACE, TOTUȘI, ȘI COMENZI FERME LA 


EDITURA TEHNICĂ, PIAŢA SCINTEII 1, BUCUREȘTI. 

Comenzile întreprinderilor se semnează de director şi contabil șef, cele ale citi- 
torilor individuali au indicată adresa exactă. Comenzile se trimit de editură la cen- 
trele de librării, cu indicarea unor priorităţi de satisfacere a lor. Plata nu se face 
decit la primirea exemplarelor. 


e Aveţi in față o carte intr-adevâr mult așteptată: prima carte edi- 
tată in România insoţită (o parte a tirajului) de o casetă magnetică ce 
acționează calculatoare personaie. 

e Este adresată celor care studiază sau lucrează in electronică — 
automatizări — informatică — tehnică de colcul, cum și tuturor utilizatorilor 
actuali sou potențiali de microprocesoare, din toate ramurile economiei 
naționale. 

e Cunoașterea funcționării intime a microprocesorului 280 (cel mai 
răspindit in țară drept „creier electronic“ al echipamentelor de calcul și de 
automatizare, alături de mai vechiul 18080, pe care ii depășește cu muli, 
dar cu care este compatibil unilateral), ca și proiectarea electronică a uti- 
lajelor dotate cu acest microprocesor este posibilă atit pentru cititorii care 
au acces io un calculator personal PRAE sau aMIC, cit și pentru cei core 
nu ou. Aceasta, pentru că peste 200 din secvențele esențiale pe care simu- 
latorul VISIBLE-—Z 80, aflat pe caseta din casetofon, le redă dinamic pe 
ecranul monitorului sau televizorului atașat calculatorului personal sint selec- 
tate și imprimate in carte, cu numeroase explicații și comentarii. 


